题目描述
佳佳最近办了一张银行卡,想设置个好记密码,但用生日吧,容易被破解,不安全;如果设置不好记的密码,又担心自己也会忘记;如果写在纸上,担心纸张被别人发现或弄丢了... 佳佳有个想法:把自己名字的拼音字母转换为6位数字(密码)。变换的过程如下:第一步. 把字符串6个一组折叠起来(不足6个的话右边补0,见样例输出),比如lijiajia则变为:
lijiaj
ia
第二步. 把所有垂直在同一个位置的字符的ascii码值相加,得出6个数字,如上面的例子,则得出:213 202 106 105 97 106 第三步. 再把每个数字“缩位”处理:就是把每个位的数字相加,得出的数字如果不是一位数字,就再缩位,直到变成一位数字为止。例如: 97 => 9+7=16 => 1+6=7 上面的数字缩位后变为:647677, 这就是最后的密码。但佳佳编程太烂了,想你帮忙写一个程序。
输入
第一行输入一个整数n(n<1000),表示下边有n输入行,接下来是n行字符串(全为字母且长度小于40)。
输出
每一行输出变换后的6位密码。
样例输入
6
zhangfeng
wangximing
jiujingfazi
woaibeijingtiananmen
haohaoxuexi
lisi
样例输出
772243
344836
297332
716652
875843
佳佳最近办了一张银行卡,想设置个好记密码,但用生日吧,容易被破解,不安全;如果设置不好记的密码,又担心自己也会忘记;如果写在纸上,担心纸张被别人发现或弄丢了... 佳佳有个想法:把自己名字的拼音字母转换为6位数字(密码)。变换的过程如下:第一步. 把字符串6个一组折叠起来(不足6个的话右边补0,见样例输出),比如lijiajia则变为:
lijiaj
ia
第二步. 把所有垂直在同一个位置的字符的ascii码值相加,得出6个数字,如上面的例子,则得出:213 202 106 105 97 106 第三步. 再把每个数字“缩位”处理:就是把每个位的数字相加,得出的数字如果不是一位数字,就再缩位,直到变成一位数字为止。例如: 97 => 9+7=16 => 1+6=7 上面的数字缩位后变为:647677, 这就是最后的密码。但佳佳编程太烂了,想你帮忙写一个程序。
输入
第一行输入一个整数n(n<1000),表示下边有n输入行,接下来是n行字符串(全为字母且长度小于40)。
输出
每一行输出变换后的6位密码。
样例输入
6
zhangfeng
wangximing
jiujingfazi
woaibeijingtiananmen
haohaoxuexi
lisi
样例输出
772243
344836
297332
716652
875843
967600
简单的字符串处理而已
#include<iostream>
#include<cstring>
using namespace std;
int main()
{
int n;
cin>>n;
while(n--)
{
char s[1002];
int asc[7]={0},sum=0,i;
int len,x;
cin>>s;
len=strlen(s);
for(i=0;i<len;i++)
asc[i%6] += s[i];
for(i=0;i<6;i++)
{
int temp=0,sum=0;
while(asc[i])
{
sum += asc[i]%10;
asc[i] /= 10;
while(sum/10)
{
while(sum)
{
temp += sum%10;
sum/=10;
}
sum = temp;
}
}
cout<<sum;
}
cout<<endl;
}
return 0;
}