PAT 1067. 试密码(20)-乙级

当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死。本题就请你实现这个小功能。

输入格式:

输入在第一行给出一个密码(长度不超过20的、不包含空格、Tab、回车的非空字符串)和一个正整数N(<= 10),分别是正确的密码和系统允许尝试的次数。随后每行给出一个以回车结束的非空字符串,是用户尝试输入的密码。输入保证至少有一次尝试。当读到一行只有单个#字符时,输入结束,并且这一行不是用户的输入。

输出格式:

对用户的每个输入,如果是正确的密码且尝试次数不超过N,则在一行中输出“Welcome in”,并结束程序;如果是错误的,则在一行中按格式输出“Wrong password: 用户输入的错误密码”;当错误尝试达到N次时,再输出一行“Account locked”,并结束程序。

输入样例1:
Correct%pw 3
<

### 关于 PAT 乙级 1067 题的 C 语言解决方案 对于 PAT 乙级 1067 题目,即密码问题,在处理时需注意输入输出的要求以及如何有效地比较字符串来判断用户输入是否匹配给定的正确密码。下面提供一种基于此需求设计的方法。 #### 输入与预处理 程序启动后会接收两部分初始数据:一是设定好的正确密码(长度不超过20字符),二是最大错误尝次数N(不大于10次)。之后循环读取多行代表每次尝输入的内容直到遇到特殊标记`#`为止[^2]。 ```c #include <stdio.h> #include <string.h> int main() { char correctPassword[21]; // 存储正确的密码 int maxAttempts; scanf("%s %d", correctPassword, &maxAttempts); getchar(); // 吃掉换行符 // ...后续逻辑... } ``` #### 尝验证流程 每当接收到新的尝时,应将其同之前保存下来的正确答案做对比;如果两者一致,则立即终止整个过程并告知成功登录;反之则减少剩余可失败的机会数量,并依据当前状态决定下一步动作——要么继续等待下一次猜测,要么因耗尽机会而提示锁定账户[^5]。 ```c while(maxAttempts--) { static char attempt[21]; fgets(attempt, sizeof(attempt), stdin); if(strcmp(attempt, "#\n") == 0) break; if(strcmp(correctPassword, strtok(attempt, "\r\n")) == 0){ puts("Welcome"); return 0; } } if(!maxAttempts) puts("Account locked"); else puts("Game over"); return 0; ``` 上述代码片段展示了核心功能实现方式,其中包含了基本控制结构的选择语句(`if`)和循环机制(`while`)的应用,同时也体现了标准库函数如`strcmp()`用于字符串操作的重要性。
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值