密码生成器
计算机113 袁博
1、把字符串6个一组折叠起来,比如xiaoyuanhaha则变为:
Xiaoyuan
Haha
2、 把所有垂直在同一个位置的字符的ascii码值相加,得出6个数字,如上面的例子,则得出:
124 115 665 228 214 445
3、 再把每个数字“缩位”处理:就是把每个位的数字相加,得出的数字如果不是一位数字,就再缩位,直到变成一位数字为止。例如: 124 => 1+2+4=7 => 1+2=3
上面的数字缩位后变为:344836, 这就是程序最终的输出结果!
要求程序从标准输入接收数据,在标准输出上输出结果。
输入格式为:第一行是一个整数n(<100),表示下边有多少输入行,接下来是n行字符串,就是等待变换的字符串。
输出格式为:n行变换后的6位密码。
运行效果实现:
Xiaoyuan
Haha
Aiaiaiai
Womendoushihaohaizi
Aisilezuotian
则输出:
772243
344836
297332
716652
875843
实现的代码如下:
import java.util.Scanner;
public class NIne {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int num = scanner.nextInt();
int j = num;
String[] strings = new String[num];
for(int i = 0; i < num; i++)
{
Scanner scanner1 = new Scanner(System.in);
strings[i] = scanner1.nextLine();
}
while(num > 0)
{
System.out.println(mima(strings[j - num]));
num--;
}
}
static String mima(String s)
{
char[] c = s.toCharArray();
//int count = c.length / 6;
int sum[] = {0,0,0,0,0,0};
int length = 0;
if(c.length % 6 == 0)
length = c.length / 6;
else{
length = c.length / 6 + 1;
}
int i = 0;
int j = 0;
//System.out.println(length);
while(i < 6)
{
if(i >= c.length % 6 && j * 6 + i >= c.length)
sum[i] = sum[i] + 0;
else{
sum[i] = sum[i] + c[j * 6 + i];
}
j++;
if(j == length)
{
i++;
j = 0;
}
}
//System.out.println(sum[0]+" "+sum[1] + " " + sum[2]+ " " + sum[3]+ " " + sum[4]+ " " + sum[5]);
int[] mima = new int[6];
String mimastring = "";
i = 0;
for(int num:sum)
{
mima[i] = getnum(num);
mimastring = mimastring.concat(String.valueOf(mima[i]));
i++;
}
return mimastring;
}
static int getnum(int sum)
{
int num = 0;
char[] c = String.valueOf(sum).toCharArray();
int i = 0;
while(i < c.length){
num += Integer.parseInt(String.valueOf(c[i]));
if(num >= 10)
{
num = getnum(num);
}
i++;
}
return num;
}
浙公网安备 33010602011771号