PAT Basic 1067. 试密码(20)(C语言实现)
来源:互联网 发布:linux 查看压缩包格式 编辑:程序博客网 时间:2024/06/05 20:55
题目
当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死。本题就请你实现这个小功能。
输入格式:
输入在第一行给出一个密码(长度不超过20的、不包含空格、Tab、回车的非空字符串)和一个正整数N(<= 10),分别是正确的密码和系统允许尝试的次数。随后每行给出一个以回车结束的非空字符串,是用户尝试输入的密码。输入保证至少有一次尝试。当读到一行只有单个#字符时,输入结束,并且这一行不是用户的输入。
输出格式:
对用户的每个输入,如果是正确的密码且尝试次数不超过N,则在一行中输出“Welcome in”,并结束程序;如果是错误的,则在一行中按格式输出“Wrong password: 用户输入的错误密码”;当错误尝试达到N次时,再输出一行“Account locked”,并结束程序。
输入样例1:
Correct%pw 3
correct%pw
Correct@PW
whatisthepassword!
Correct%pw
#
输出样例1:
Wrong password: correct%pw
Wrong password: Correct@PW
Wrong password: whatisthepassword!
Account locked
输入样例2:
cool@gplt 3
coolman@gplt
coollady@gplt
cool@gplt
try again
#
输出样例2:
Wrong password: coolman@gplt
Wrong password: coollady@gplt
Welcome in
思路
很考察思路严谨的一道题,真的要考虑周全输入密码时的情况。
正确密码是没有任何空白字符的,而用户输入可以再一行内任意输入,因此接受用户输入应该以换行符为判断标准。
C不方便的地方就是读字符串必须提前设定长度,而这道题的用户输入并没有任何限制,因此在程序中应该考虑防溢出的机制:
- 我每次只读20个字符或者读到换行,达到这样的目的,使用了
scanf("%20[^\n]")
,[^...]
能够读取到^后边的字符,而不是%s
读到空白字符。 - 如果用户还有输入,再逐一读取字符,一直输出到换行,这样保证了程序的健壮性。
代码
最新代码@github,欢迎交流 ^_^
#include <ctype.h>#include <stdio.h>#include <string.h>int main(){ int N; char c, correct[21], user[21]; scanf("%s %d", correct, &N); while(getchar() != '\n'); while(N--) { scanf("%20[^\n]", user); c = ungetc(getchar(), stdin); if(!strcmp(user, "#") && c == '\n') { break; } else if(!strcmp(correct, user) && c == '\n') { puts("Welcome in"); break; } else { printf("Wrong password: %s", user); while(putchar(getchar()) != '\n') ; if(!N) puts("Account locked"); } } return 0;}
- PAT Basic 1067. 试密码(20)(C语言实现)
- PAT Basic 1004. 成绩排名 (20)(C语言实现)
- PAT Basic 1009. 说反话 (20)(C语言实现)
- PAT Basic 1012. 数字分类 (20)(C语言实现)
- PAT Basic 1013. 数素数 (20)(C语言实现)
- PAT Basic 1019. 数字黑洞 (20)(C语言实现)
- PAT Basic 1027. 打印沙漏(20)(C语言实现)
- PAT Basic 1028. 人口普查(20)(C语言实现)
- PAT Basic 1029. 旧键盘(20)(C语言实现)
- PAT Basic 1034. 有理数四则运算(20)(C语言实现)
- PAT Basic 1042. 字符统计(20)(C语言实现)
- PAT Basic 1043. 输出PATest(20)(C语言实现)
- PAT Basic 1044. 火星数字(20)(C语言实现)
- PAT Basic 1047. 编程团体赛(20)(C语言实现)
- PAT Basic 1048. 数字加密(20)(C语言实现)
- PAT Basic 1052. 卖个萌 (20)(C语言实现)
- PAT Basic 1054. 求平均值 (20)(C语言实现)
- PAT Basic 1057. 数零壹(20)(C语言实现)
- PAT Basic 1064. 朋友数(20)(C语言实现)
- PAT Basic 1065. 单身狗(25)(C语言实现)
- PAT Basic 1035. 插入与归并(25)(C语言实现)
- The Structure of jQuery
- PAT Basic 1066. 图像过滤(15)(C语言实现)
- PAT Basic 1067. 试密码(20)(C语言实现)
- PAT Basic 1068. 万绿丛中一点红(20)(C语言实现)
- PAT Basic 1069. 微博转发抽奖(20)(C语言实现)
- PAT Basic 1070. 结绳(25)(C语言实现)
- PAT Basic 1000. Index & About
- PAT Advanced 1001. A+B Format (20) (C语言实现)
- PAT Advanced 1002. A+B for Polynomials (25) (C语言实现)
- PAT Advanced 1004. Counting Leaves (30) (C语言实现)
- JS 正则表达式全匹配和部分匹配