简单的ASCII码字符串加密

#include <stdlib.h>
#include <stdio.h>
#include <string.h>

 

#define MAX 128

 

void encrypt(char *str , char *toStr) ;
void decrypt(char *str , char *toStr) ;

 

int main()
{
 char str[100] ;
 char toStr[100] ;
 char finStr[100] ;
 printf("请输入一字符串:") ;
 scanf("%s" , str) ;

 thrice_Encrypt(str , toStr) ;
 printf("加密后的字符串为:/n%s/n" , toStr) ;

 thrice_Decrypt(toStr , finStr) ;
 printf("解密后的字符串为:/n%s/n" , finStr) ;
 system("pause") ;
}

 

void encrypt(char *str , char *toStr)
{
 int add = strlen(str) % MAX ;
 char str_1[100] ;
 int i = 0 ;
 int temp = 0 ;
 while(str[i] != '/0')
 {
  temp = str[i] + add ;
  if(temp >= MAX)        /判断是否超出128 。。。
   str_1[i] = str[i] + add - MAX + 1;
  else str_1[i] = str[i] + add ;
  i++ ;
 }
 str_1[i] = '/0' ;
 strcpy(toStr , str_1) ;
}

 

void decrypt(char *str , char *toStr)
{
 int sub = strlen(str) % MAX ;
 char str_1[100] ;
 int i = 0 ;
 while(str[i] != '/0')
 {
  if(str[i] <= sub)
  {
   str_1[i] = str[i] + MAX - sub - 1;
  }
  else
   str_1[i] = str[i] - sub ;
  i++ ;
 }
 str_1[i] = '/0' ;
 strcpy(toStr , str_1) ;
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
字符串加密是指将一个字符串按照某种规则进行加密,使得加密后的字符串能够更好地保护数据安全。以下是一个简单的 C++ 字符串加密代码,通过将字符串中的每个字符进行移位操作来实现加密: ```c++ #include <iostream> #include <string> using namespace std; string encrypt(string str, int key) { string res = ""; for (char c : str) { if (isalpha(c)) { char base = isupper(c) ? 'A' : 'a'; res += (c - base + key) % 26 + base; } else { res += c; } } return res; } int main() { string str; int key; cout << "Please input the string you want to encrypt: "; getline(cin, str); cout << "Please input the encryption key: "; cin >> key; string res = encrypt(str, key); cout << "The encrypted string is: " << res << endl; return 0; } ``` 在 `encrypt()` 函数中,我们首先遍历输入字符串 `str` 中的每个字符,如果该字符是字母,则将其转换为大写或小写,并计算其移位后的字符。具体来说,我们先计算出当前字符所在的字母表中的位置 `pos`,然后加上移位量 `key` 得到新的位置 `new_pos`,最后将其转换为对应的字符并加入结果字符串 `res` 中。如果该字符不是字母,则直接加入结果字符串中。在计算位置时,我们使用了 ASCII 表中字母的顺序,即大写字母从 `65` 开始,小写字母从 `97` 开始,因此需要根据当前字符是否为大写字母来选择对应的基准值。 希望对您有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值