C语言 字符串加密解密

C语言加密解密

当用户输入字符串后 字符串 传入加密函数 进行加密,返回加密后的结果。

解密也是同理。

加 i 的值是因为 i 是不断增加的 这样会使得加密后的值不会直接找到规律
加密 偏移量也可以用别的值替代。

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define KEY 5  // 偏移量 

/**
*根据传入的字符串
* 参数1 要加密的字符串
*  返回加密后的参数
*/

char * encrypt(char[]);//加密
char * encryptr(char[]); //解密 

int main()
{
    
    
 char name[100]; 
 printf("请输入需要加密的字符:");
 scanf("%s",name);
 encrypt(name);
 printf("\n加密后的字符为:%s",name);
 printf("\n");
 printf("请输入需要解密的字符:");
 scanf("%s",name);
 encryptr(name);
 printf("\n解密后的字符为:%s",name); 
 return 0;
}


char * encrypt(char str[])  //字符串加密 
{
    
    
 int i; 
 int count=strlen(str);  //字符串长度
 for(i=0;i<count;i++)    //为什么for循环里不直接用strlen(str)量,因为for循环会每循环一次 就测量一次 所以不推荐使用
 {
    
    
  str[i]=str[i]+i+KEY; //str数组中的第i个值加上i的值加上偏移量
 } 
 return str;   //返回加密后的的字符串 
}

char * encryptr(char str[]) //解密
{
    
    
 int i;
 int count=strlen(str);  //字符串长度 
 for(i=0;i<count;i++)
 {
    
    
  str[i]=str[i]-i-KEY; //str数组中的第i个值减去i的值减去偏移量
 }
 return str;  //返回解密后的字符串 
} 

猜你喜欢

转载自blog.csdn.net/weixin_44848436/article/details/102711098
今日推荐