P1067 试密码
P1067 试密码
转跳点:
1067 试密码 (20分)
当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死。本题就请你实现这个小功能。
输入格式:
输入在第一行给出一个密码(长度不超过 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
坑啊,这道题,简直狗到爆啊,测试点2一直没过,3个小时就一直在debug,太狗了……
第一个坑点(最坑的地方): 第一行给出的密码和数字后面不一定紧跟换行符就这一点就把我坑惨了一定要注意
第二个坑点:用户输入没有任何限制,没错,测试点毛限制都没有,可能会有空格,可能不止20个字符,可能……(就像我们当初用软件瞎搞的时候,真是风水轮流转)
有个麻烦的地方就是输入与正确密码的比较如果存储成字符数组的话每一次比较都需要,而且个人不太擅长处理字符串,所以我把密码按ASCII码给加起来了,每次输入的字符都加起来,然后和密码的大小相比,这样子可以避免坑点二2 输入字符过长的问题,就算按输入100个127也就12700。不过很显然这种思路是有问题的ab和ba就没有办法识别,但是把,在PAT上居然A了……我没有管用户多余的输入(好吧这不太好)
我第一次AC的代码(无法识别ab 和ba的区别):
#include <stdio.h>
#include <stdlib.h> int PasswordSum(int mode); char Word[23] = "\0"; int main(void)
{
char ch;
int n, i, Password, sum = 0; Password = PasswordSum(0); scanf("%d", &n);
getchar(); for (i = 0; i < n; i++)
{
sum = PasswordSum(1);
if (((int)'#') == sum)
{
break;
}
if (sum == Password)
{
printf("Welcome in\n");
break;
}
printf("Wrong password: %s\n", Word);
} if (i == n)
{
printf("Account locked");
} return 0;
} int PasswordSum(int mode)
{
char ch, BKCh;
int i = 0, sum = 0; BKCh = 1 == mode ? '\n' : ' '; while (BKCh != (ch = getchar()))
{
sum += ch - '\0';
Word[i++] = ch;
}
Word[i] = '\0'; return sum;
}
第二次AC代码:
这次用了点正则,大部分使用了内置函数库我每次只读20个字符或者读到换行,达到这样的目的,使用了scanf("%20[^\n]"),[^...]能够读取到^后边的字符,而不是%s读到空白字符。 如果用户还有输入,再一个个读取字符,一直输出到换行,这样保证了程序的健壮性。
#include <ctype.h>
#include <stdio.h>
#include <string.h> int main()
{
int n;
char ch, Password[21], user[21]; scanf("%s %d", Password, &n);
while (getchar() != '\n')
;
while (n--)
{
scanf("%20[^\n]", user);
ch = ungetc(getchar(), stdin);
if (!strcmp(user, "#") && ch == '\n')
{
break;
}
else if (!strcmp(Password, user) && ch == '\n')
{
puts("Welcome in");
break;
}
else
{
printf("Wrong password: %s", user);
while (putchar(getchar()) != '\n')
;
if (0 == n)
{
puts("Account locked");
}
}
} return 0;
}
PTA不易,诸君共勉!
P1067 试密码的更多相关文章
- PAT 乙级 1067 试密码(20 分)
1067 试密码(20 分) 当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死.本题就请你实现这个小功能. 输入格式: 输入在第一行给出一个密码(长度 ...
- PAT 1067 试密码(20)(代码)
1067 试密码(20 分) 当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死.本题就请你实现这个小功能. 输入格式: 输入在第一行给出一个密码(长度 ...
- PAT(B) 1067 试密码(Java)
题目链接:1067 试密码 (20 point(s)) 题目描述 当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死.本题就请你实现这个小功能. 输入格 ...
- PAT1067 试密码 (20分)——测试点4分析 一个易错点
1067 试密码 (20分) 当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死.本题就请你实现这个小功能. 输入格式: 输入在第一行给出一个密码( ...
- PAT 1067 试密码
https://pintia.cn/problem-sets/994805260223102976/problems/994805266007048192 当你试图登录某个系统却忘了密码时,系统一般只 ...
- PAT 1067. 试密码(20)
当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死.本题就请你实现这个小功能. 输入格式: 输入在第一行给出一个密码(长度不超过20的.不包含空格.Ta ...
- PAT - 1067 试密码 (20 分)
当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死.本题就请你实现这个小功能. 输入格式: 输入在第一行给出一个密码(长度不超过 20 的.不包含空格. ...
- PAT Basic 1067 试密码 (20 分)
当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死.本题就请你实现这个小功能. 输入格式: 输入在第一行给出一个密码(长度不超过 20 的.不包含空格. ...
- 1067 试密码 (20分)C语言
当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死.本题就请你实现这个小功能. 输入格式: 输入在第一行给出一个密码(长度不超过 20 的.不包含空格. ...
随机推荐
- 编译安装nginx错误解决!
编译安装执行 ./configure --prefix=/root/web/nginx --sbin-path=/root/web/nginx/sbin/nginx --conf-path=/root ...
- Linux查看当前系统32位还是64位
getconf LONG_BIT 此方法会直接返回32或64
- JAVAWeb问题总结(持续更新)
1.在JSP页面头部,出现如下错误: 错误文本: Multiple annotations found at this line: - The superclass "javax.servl ...
- nodejs的POST两种type类型提交(原生)
POST数据的两种提交格式 application/x-www-form-urlencoded(上传数据中没有文件) multipart/form-data (文件上传) 获取POST数据,post数 ...
- 软件工程 - 防御式编程EAFP vs LBYL
概念 EAFP:easier to ask forgiveness than permission LBYL:look before you leap 代码 # LBYL def getUserInf ...
- C++:面向对象的相关概念
对象: 一般意义上的对象:是现实世界中一个实际存在的事物 面向对象方法中的对象:是系统中用来描述客观事物的一个实体 抽象与分类: 分类所依据的原则:抽象 抽象出同一类对象的共同属性和行为,形成类 类与 ...
- Kali中文乱码问题
上面的是用网上介绍的安装组件无法安装,老是提示最后一句:Unable to locate package ...... 后来觉得应该是因为安装Kali时在最后有个选择更新系统的一个配置上,我选择了下面 ...
- ch8 让div居中--使用外边距
假设有一个布局,希望让其中的容器div在屏幕上水平居中,则只需要定义div的宽度,然后将水平外边距设置为auto <body> <div class="wrapper&qu ...
- python--一起来盖个时间戳!!
1.datetime import datetime print(datetime.datetime.now()) 2.time import time otherStyleTime = time.s ...
- Day11 - J - Brave Game HDU - 1846
十年前读大学的时候,中国每年都要从国外引进一些电影大片,其中有一部电影就叫<勇敢者的游戏>(英文名称:Zathura),一直到现在,我依然对于电影中的部分电脑特技印象深刻.今天,大家选择上 ...