数据结构——文本串加密

一个文本串可用事先给定的字母映射表进行加密。例如,假设字母映射表为:
a b c d e f g h i j k l m n o p q r s t u v w x y z
n g z q t c o b m u h e l k p d a w x f y i v r s j
则字符串“encrypt”被加密为“tkzwsdf”

要求:熟悉串的顺序存储结构,设计程序将输入的文本串进行加密后输出,然后进行解密并输出。

#include <malloc.h>
#include <stdio.h> 
#include <String.h>
#define MaxSize  100
typedef  struct
{   
	char data[MaxSize] ;
	int length;
}SqString;   
void StrAssign(SqString &s,char cstr[])	//s为引用型参数
{  
	int i;
    for (i=0;cstr[i]!='\0';i++)
		s.data[i]=cstr[i];
    s.length=i;
}
void DispStr(SqString s)
{ 
	int i;
    if (s.length>0)
    {  
		for(i=0;i<s.length;i++)
	   		printf("%c",s.data[i]);
		printf("\n");
    }
}
SqString EnCrypt(SqString p,SqString A,SqString B) //加密,p是需要加密的串,A是初始串,B是映射串 
{
	int i=0,j;
	SqString q;		//加密后的串 
	while(i<p.length)
	{
		for(j=0;p.data[i]!=A.data[j]&& j < A.length;j++);	//在A中找p.data[i],返回位置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,SqString A,SqString B) //解密,q是已经加密的串,A是初始串,B是映射串
{
	int i=0,j;
	SqString p;		//解密后的串 
	while(i<q.length)
	{
		for(j=0;q.data[i]!=B.data[j]&& j < B.length;j++);	//在B中找p.data[i],返回位置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;
} 


int main(int argc, char** argv) {
	
	char strA[] = "abcdefghijklmnopqrstuvwxyz";
	char strB[] = "ngzqtcobmuhelkpdawxfyivrsj";
	
	SqString A;
	SqString B;
	StrAssign(A,strA);
	StrAssign(B,strB);
	
	SqString p,q;
	char str[100];
	printf("输入原文串:");
	gets(str);
	StrAssign(p,str);
	
	printf("加密解密如下:\n");
	printf("  原文串:"); 
	DispStr(p);
	q=EnCrypt(p,A,B);
	printf("  加密串:"); 
	DispStr(q);
	p=UnEnCrypt(q,A,B);
	printf("  解密串:"); 
	DispStr(p);
	
	return 0;
}

运行效果

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值