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 的.不包含空格. ...
随机推荐
- JIRA 安装与破解 Mac版
1.安装 JDK 2.安装 MySQL 下载地址:https://dev.mysql.com/downloads/ 选择对应版本下载安装.我选择的是 mysql-8.0.11-macos10.13-x ...
- HDU 1035 Robot Motion(dfs + 模拟)
嗯... 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1035 这道题比较简单,但自己一直被卡,原因就是在读入mp这张字符图的时候用了scanf被卡. ...
- CURL_模拟登录
<?php $curl = curl_init(); $url = "http://www.imooc.com/user/login"; //$url = "htt ...
- JavaScript图形实例:圆内螺线
数学中有各式各样富含诗意的曲线,螺旋线就是其中比较特别的一类.螺旋线这个名词来源于希腊文,它的原意是“旋卷”或“缠卷”.例如,平面螺旋线便是以一个固定点开始向外逐圈旋绕而形成的曲线. 阿基米德螺线和黄 ...
- CSS阴影 box-shadow属性用法
box-shadow: 它可以设置一个或者多个下拉阴影的框 语法:box-shadow:h-shadow v-shadow blur spread color inset 注意:该属性把一个或者多个下 ...
- 牛茶冲天的ip命令
一.修改二层链路相关设置 1.修改网卡名称(修改前要先停止) ip link set eth0 name testname 2.修改网卡地址 ip link set eth0 address xxx ...
- 7 JavaScript函数调用&this关键字&全局对象&函数调用&闭包
JavaScript函数有4种调用方式,每种方式的不同之处在于this的初始化 一般而言,在JavaScript中,this指向函数执行时的当前对象 如果函数不属于任何对象,那么默认为全局对象,即HT ...
- c++构造函数的初始化列表(翁恺c++公开课[13])
初始化列表形式: class Point { private: const float x,y; Point(float xa = 0.0, flato ya = 0.0):y(ya),x(xa) { ...
- LeetCode 345. Reverse Vowels of a String(双指针)
题意:给定一个字符串,反转字符串中的元音字母. 例如: Input: "leetcode" Output: "leotcede" 法一:双指针 class So ...
- 【Python数据挖掘】第六篇--特征工程
一.Standardization 方法一:StandardScaler from sklearn.preprocessing import StandardScaler sds = Standard ...