第八周实践项目4 字符串加密
生活随笔
收集整理的這篇文章主要介紹了
第八周实践项目4 字符串加密
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
/*?
*Copyright?(c)?2017,煙臺大學計算機與控制工程學院?
*All?rights?reserved.?
*文件名稱:項目-?
一個文本串可用事先編制好的字符映射表進行加密。例如,設字符映射表為:
abcdefghijklmnopqrstuvwxyz
ngzqtcobmuhelkpdawxfyivrsj
*作????者:邵雪源?
*完成日期:2017年12月14日?
*版?本?號:v1.0?
*/??
#include <stdio.h>
#define MaxSize 100 //最多的字符個數
typedef struct
{ char data[MaxSize]; //定義可容納MaxSize個字符的空間int length; //標記當前實際串長
} SqString;
SqString A,B; //用于存儲字符映射表
void StrAssign(SqString &s,char *cstr) //s為引用型參數
{ 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串加密產生q串printf(" 加密串:");DispStr(q);p=UnEncrypt(q); //q串解密產生p串printf(" 解密串:");DispStr(p);printf("\n");return 0;
}
總結
以上是生活随笔為你收集整理的第八周实践项目4 字符串加密的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 第七周实践项目6 停车场模拟(栈和队列
- 下一篇: 第八周实践项目 5 计数的模式匹配