蓝桥杯 密码发生器 day8

该博客介绍了蓝桥杯比赛中的一种密码生成方法,将拼音字符串转化为6位数字密码。方法包括字符串折叠、ASCII码相加及数字缩位处理。通过示例解释了输入输出格式,并提醒注意取余和循环操作,防止字母输入错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目
题目描述
在对银行账户等重要权限设置密码的时候,我们常常遇到这样的烦恼:如果为了好记用生日吧,容易被破解,不安全;如果设置不好记的密码,又担心自己也会忘记;如果写在纸上,担心纸张被别人发现或弄丢了。
这个程序的任务就是把一串拼音字母转换为 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<100),表示下边有多少输入行,
接下来是 nn 行字符串,就是等待变换的字符串。
输出描述
输出 nn 行变换后的 6 位密码。
输入输出样例
示例
输入
5
zhangfeng
wangximing
jiujingfazi
woaibeijingtiananmen
haohaoxuexi
输出
772243
344836
297332
716652
875843

总结
善用取余和while循环,还有长得很像的字母不要在敲的时候打错了…

PASS代码

#include <stdio.h>
#include <stri
### 蓝桥杯 Java 第一天 学习资料与教程 对于希望参与蓝桥杯竞赛并专注于Java编程的学习者而言,初期准备阶段至关重要。首日的学习应当聚焦于夯实基础概念和技术要点。 #### 基础知识回顾 在开始深入研究之前,建议复习计算机科学的基础理论和算法设计原则。这不仅有助于理解后续更复杂的内容,还能提高解决问题的能力[^3]。 #### 获取高质量资源 由于优快云平台对上传图片的质量有限制,因此推荐通过其他渠道获得详细的电子版教材。例如,在微信公众号【一只阿欢】中回复特定关键词可以得到关于蓝桥杯Java B组学习材料、文件操作指南及考试重点解析的PDF文档下载链接[^1]。 #### 实践练习 为了更好地掌握所学的知识点,应该积极参与实际编码训练。可以从简单的例子入手,比如编写计算日期天数的小程序来熟悉语法结构: ```java public class Main { public static void main(String[] args) { System.out.println(31 + 29 + 31 + 30 + 4); } } ``` 这段代码展示了如何利用基本算术运算实现功能需求[^2]。 #### 数据结构入门 了解常用的数据结构也是必不可少的一部分。以`TreeSet`为例,这是一种能够自动维护元素顺序集合类;当自定义比较器时,则可以根据指定规则来进行排序处理: ```java import java.util.*; class MyClass implements Comparable<MyClass> { int a; int b; public MyClass(int a, int b) { this.a = a; this.b = b; } @Override public String toString() { return "MyClass{" + "a=" + a + ", b=" + b + '}'; } @Override public int compareTo(MyClass o) { if (this.a != o.a) return Integer.compare(this.a, o.a); else return Integer.compare(this.b, o.b); } } class MyComparator implements Comparator<MyClass> { @Override public int compare(MyClass m1, MyClass m2) { if (m1.a != m2.a) return Integer.compare(m1.a, m2.a); else return Integer.compare(m1.b, m2.b); } } public class TreeSetExample { public static void main(String[] args) { TreeSet<MyClass> treeSet = new TreeSet<>(new MyComparator()); treeSet.add(new MyClass(1, 2)); treeSet.add(new MyClass(2, 2)); treeSet.add(new MyClass(2, 3)); treeSet.add(new MyClass(4, 3)); treeSet.add(new MyClass(5, 6)); treeSet.add(new MyClass(7, 3)); Iterator<MyClass> it = treeSet.iterator(); while (it.hasNext()) { System.out.println(it.next().toString()); } } } ``` 此段代码说明了如何创建带有自定义比较逻辑的`TreeSet`实例,并向其中添加对象后遍历输出结果。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值