JAVA蓝桥杯(19)密码发生器
来源:互联网 发布:四维星装饰选材软件 编辑:程序博客网 时间:2024/05/18 02:32
问题描述
把一串拼音字母转换为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(<100),表示下边有多少输入行,接下来是n行字符串,就是等待变换的字符串。
输出格式为:n行变换后的6位密码。
例如,输入:
5
zhangfeng
wangximing
jiujingfazi
woaibeijingtiananmen
haohaoxuexi
则输出:
772243
344836
297332
716652
875843
解决方法
import java.util.ArrayList;import java.util.Iterator;import java.util.List;import java.util.Scanner;import java.util.Vector;public class Question19 { private static Scanner scanner = new Scanner(System.in); public static void main(String[] args) { int n = Integer.parseInt(scanner.nextLine()); Vector<String> vector = new Vector<String>(); for (int i = 0; i < n; i++) { vector.add(scanner.nextLine()); } for (Iterator<String> iterator = vector.iterator(); iterator.hasNext();) { String string4 = (String) iterator.next(); List<String> strings = zhedie(string4); ascii(strings); } } private static void suowei(int[] n) {// 缩位函数 for (int i = 0; i < n.length; i++) { char[] a = String.valueOf(n[i]).toCharArray(); int sum = 0; boolean flag = true; while (flag) { for (int j = 0; j < a.length; j++) { String b = a[j] + ""; int c = Integer.valueOf(b); sum += c; } if (String.valueOf(sum).length() == 1) { flag = false; } else { a = String.valueOf(sum).toCharArray(); sum = 0; } } System.out.print(sum); } System.out.println(); } private static void ascii(List<String> strings) {// 获得ASCII码 int[] is = new int[6]; for (int i = 0; i < strings.size(); i++) { String tmp = strings.get(i); for (int j = 0; j < tmp.length(); j++) { is[j] += tmp.charAt(j); } } suowei(is); } private static List<String> zhedie(String string) {// 折叠 List<String> strings = new ArrayList<String>(); StringBuffer stringBuffer = new StringBuffer(); for (int i = 0; i < string.length(); i++) { if (i % 6 == 0 && i != 0) { strings.add(stringBuffer.toString()); stringBuffer.delete(0, stringBuffer.length()); } stringBuffer.append(string.charAt(i)); } strings.add(stringBuffer.toString()); return strings; }}
运行结果
5zhangfengwangximingjiujingfaziwoaibeijingtiananmenhaohaoxuexi772243344836297332716652875843
0 0
- JAVA蓝桥杯(19)密码发生器
- java 蓝桥杯 密码发生器
- 密码发生器 (蓝桥杯)
- 密码发生器(蓝桥杯2012)
- 南桥杯Java 密码发生器
- 南阳理工:密码发生器(蓝桥杯2012)
- 密码发生器--蓝桥杯
- NYOJ 密码发生器(蓝桥杯)
- 蓝桥杯_密码发生器
- 蓝桥杯之密码发生器
- 蓝桥杯 密码发生器
- 蓝桥杯历届-密码发生器
- 蓝桥杯 密码发生器
- 【蓝桥杯】密码发生器
- ACM:蓝桥杯:密码发生器
- 【蓝桥杯】【密码发生器】
- 密码发生器--蓝桥杯java组历年真题
- 蓝桥杯第三届 密码发生器
- win7 caffe使用笔记——特征图可视化(matlab,python两种方式)
- php第二天
- PDF阅读
- 【spoj】【COT - Count on a tree】【可持久化线段树】
- ajax的基本流程
- JAVA蓝桥杯(19)密码发生器
- 笔试题15
- 买票(1)
- 奋斗
- web项目添加包的一些建议
- Queueing at Bank (25)
- 机器学习13大规模数据集
- BeautifulSoup安装,输入setup.py build后没反应----可能是命令错误!
- 线性表-链栈