第八周实践项目4 字符串加密
生活随笔
收集整理的這篇文章主要介紹了
第八周实践项目4 字符串加密
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
/*?
*Copyright?(c)?2017,煙臺(tái)大學(xué)計(jì)算機(jī)與控制工程學(xué)院?
*All?rights?reserved.?
*文件名稱:項(xiàng)目-?
一個(gè)文本串可用事先編制好的字符映射表進(jìn)行加密。例如,設(shè)字符映射表為:
abcdefghijklmnopqrstuvwxyz
ngzqtcobmuhelkpdawxfyivrsj
*作????者:邵雪源?
*完成日期:2017年12月14日?
*版?本?號(hào):v1.0?
*/??
#include <stdio.h>
#define MaxSize 100 //最多的字符個(gè)數(shù)
typedef struct
{ char data[MaxSize]; //定義可容納MaxSize個(gè)字符的空間int length; //標(biāo)記當(dāng)前實(shí)際串長(zhǎng)
} SqString;
SqString A,B; //用于存儲(chǔ)字符映射表
void StrAssign(SqString &s,char *cstr) //s為引用型參數(shù)
{ int i;for (i=0;cstr[i]!='\0';i++)s.data[i]=cstr[i];s.length=i;
}SqString EnCrypt(SqString p)
{int i=0,j;SqString q;while (i<p.length){for (j=0; p.data[i]!=A.data[j]&&j<A.length; j++);if (j>=A.length) //在A串中未找到p.data[i]字母q.data[i]=p.data[i];else //在A串中找到p.data[i]字母q.data[i]=B.data[j];i++;}q.length=p.length;return q;
}
SqString UnEncrypt(SqString q)
{int i=0,j;SqString p;while (i<q.length){for (j=0; q.data[i]!=B.data[j]&&j<B.length; j++);if (j>=B.length) //在B串中未找到q.data[i]字母p.data[i]=q.data[i];else //在B串中找到q.data[i]字母p.data[i]=A.data[j];i++;}p.length=q.length;return p;
}
void DispStr(SqString s)
{ int i;if (s.length>0){ for (i=0;i<s.length;i++)printf("%c",s.data[i]);printf("\n");}
}
int main()
{SqString p,q;StrAssign(A,"abcdefghijklmnopqrstuvwxyz"); //建立A串StrAssign(B,"ngzqtcobmuhelkpdawxfyivrsj"); //建立B串char str[MaxSize];printf("輸入原文串:");gets(str); //獲取用戶輸入的原文串StrAssign(p,str); //建立p串printf("加密解密如下:\n");printf(" 原文串:");DispStr(p);q=EnCrypt(p); //p串加密產(chǎn)生q串printf(" 加密串:");DispStr(q);p=UnEncrypt(q); //q串解密產(chǎn)生p串printf(" 解密串:");DispStr(p);printf("\n");return 0;
}
總結(jié)
以上是生活随笔為你收集整理的第八周实践项目4 字符串加密的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 第七周实践项目6 停车场模拟(栈和队列
- 下一篇: 第八周实践项目 5 计数的模式匹配