蓝桥杯:密码发生器

密码发生器【模拟】

题目描述

在对银行账户等重要权限设置密码的时候,我们常常遇到这样的烦恼:如果为了好记用生日吧,容易被破解,不安全;如果设置不好记的密码,又担心自己也会忘记;如果写在纸上,担心纸张被别人发现或弄丢了。

这个程序的任务就是把一串拼音字母转换为 6 位数字(密码)。我们可以使用任何好记的拼音串(比如名字,王喜明,就写:wangximing )作为输入,程序输出 6 位数字。

变换的过程如下:

第一步. 把字符串 6 个一组折叠起来,比如 wangximing 则变为:

wangxi

ming

第二步. 把所有垂直在同一个位置的字符的 ascii 码值相加,得出 6 个数字,如上面的例子,则得出:228 202 220 206 120 105

第三步.再把每个数字"缩位"处理:就是把每个位的数字相加,得出的数字如果不是一位数字,就再缩位,直到变成一位数字为止。例如: 228 => 2+2+8=12 => 1+2=3

上面的数字缩位后变为:344836, 这就是程序最终的输出结果!

要求程序从标准输入接收数据,在标准输出上输出结果。

输入描述

第一行是一个整数 n (n<100),表示下边有多少输入行,

接下来是 n 行字符串,就是等待变换的字符串。

输出描述

输出 n 行变换后的 6 位密码。

输入输出样例

示例

输入

5
zhangfeng
wangximing
jiujingfazi
woaibeijingtiananmen
haohaoxuexi

输出

772243
344836
297332
716652
875843

代码:

#include<stdio.h>
char x[200];
int s[10];
int n;

void A()
{   //第一步:把所有垂直在同一个位置的字符的 ascii 码值相加 
	for(int i=0;i<9;i++)
		s[i]=0;
	
	int cnt=0; 
	
	//将字符串分成6个储存起来
	for(int k=0;x[k]!='\0';k++)
	{
		s[cnt++]+=x[k];
		if(cnt>5) 
			cnt=0;
	}
}


void B()
{   //第二步:把每个数字"缩位"处理
	for(int k=0;k<6;k++)
	{
		int num=s[k];
		while(num>=10)
		{
			int sum=0;
			while(num)
			{
				sum+=num%10;
				num/=10;
			}
			num=sum;
		}
		s[k]=num;
	}
}


int main()
{	
	scanf("%d",&n);
	
	for(int i=0;i<n;i++)
	{
		scanf("%s",x);
		
		A(); 
		B();
		
		for(int k=0;k<6;k++)
			printf("%d",s[k]);
		printf("\n");		
	}
	return 0;	
} 
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值