第八周项目4-字符串加密

  1. /*        
  2. Copyright (c)2016,烟台大学计算机与控制工程学院        
  3. All rights reserved.        
  4. 文件名称:第8周项目4-字符串加密.cpp        
  5. 作    者:陈晓琳            
  6. 版 本 号:v1.0     
  7. 完成日期:2016年10月21
  8.    
  9.         
  10. 问题描述:一个文本串可用事先编制好的字符映射表进行加密。例如,设字符映射表为:  
  11.           abcdefghijklmnopqrstuvwxyz  
  12.           ngzqtcobmuhelkpdawxfyivrsj  
  13. 输入描述:串的输入。  
  14. 程序输出:加密后的输出。  
  15. */    

代码:

顺序串算法

[cpp]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. #include "sqstring.h"    
  2.     
  3. SqString A,B; //用于存储字符映射表    
  4.     
  5. SqString EnCrypt(SqString p)    
  6. {    
  7.     int i=0,j;    
  8.     SqString q;    
  9.     while (i<p.length)    
  10.     {    
  11.         for (j=0; p.data[i]!=A.data[j]; j++);    
  12.         if (j>=p.length)            //在A串中未找到p.data[i]字母    
  13.             q.data[i]=p.data[i];    
  14.         else                        //在A串中找到p.data[i]字母    
  15.             q.data[i]=B.data[j];    
  16.         i++;    
  17.     }    
  18.     q.length=p.length;    
  19.     return q;    
  20. }    
  21.     
  22. SqString UnEncrypt(SqString q)    
  23. {    
  24.     int i=0,j;    
  25.     SqString p;    
  26.     while (i<q.length)    
  27.     {    
  28.         for (j=0; q.data[i]!=B.data[j]; j++);    
  29.         if (j>=q.length)            //在B串中未找到q.data[i]字母    
  30.             p.data[i]=q.data[i];    
  31.         else                    //在B串中找到q.data[i]字母    
  32.             p.data[i]=A.data[j];    
  33.         i++;    
  34.     }    
  35.     p.length=q.length;    
  36.     return p;    
  37. }    
  38.     
  39. int main()    
  40. {    
  41.     SqString p,q;    
  42.     StrAssign(A,"abcdefghijklmnopqrstuvwxyz");  //建立A串    
  43.     StrAssign(B,"ngzqtcobmuhelkpdawxfyivrsj");  //建立B串    
  44.     char str[MaxSize];    
  45.     printf("\n");    
  46.     printf("输入原文串:");    
  47.     gets(str);                                  //获取用户输入的原文串    
  48.     StrAssign(p,str);                           //建立p串    
  49.     printf("加密解密如下:\n");    
  50.     printf("  原文串:");    
  51.     DispStr(p);    
  52.     q=EnCrypt(p);                               //p串加密产生q串    
  53.     printf("  加密串:");    
  54.     DispStr(q);    
  55.     p=UnEncrypt(q);                         //q串解密产生p串    
  56.     printf("  解密串:");    
  57.     DispStr(p);    
  58.     printf("\n");    
  59.     return 0;    
  60. }    
运行结果:


知识点总结:

将输入的文本进行加密后输出,然后进行解密后输出。

学习心得:

串的基本操作是应用实现的基础。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值