PAT乙级 1067 试密码 C语言

试密码

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

输入格式:

输入在第一行给出一个密码(长度不超过 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

思路分析:

这道题本质上就是一个strcmp()函数判断的过程,其实并不是很难,但是!!!坑是真的挺多的!

在开始解析坑点之前,还是先回顾一下strcmp()函数的用法。

函数的声明为:

int strcmp(const char *str1, const char *str2)
  • 如果返回值小于 0,则表示 str1 小于 str2。
  • 如果返回值大于 0,则表示 str1 大于 str2。
  • 如果返回值等于 0,则表示 str1 等于 str2。

坑点1:第一行给出的密码和数字后面不一定紧跟换行符

解决方案:加入gets()或者getchar()来吸收

坑点2:用户输入的密码不一定是在20位以内

解决方案:设置输入的数组要弄大点

坑点3:题给的例子都是以'#'结束输入(也可能是我自己认为)

我就在想是不是要所有的都要以'#'结束,哪怕超出了尝试密码的上限,这真的困扰了我很久,后来发现是我想多了。只要上限一到就应该结束输入。(当然也可以继续输入,但是这道题就是有点怪,不输入也能通过)

最后一个是while循环的条件,这里用flag来控制,flag==0,就循环,flag==1就结束循环,break跳出去。

代码:

#include <stdio.h>
#include <string.h>

int main(){
	char right[21]={0};
	int n,flag=0;
	scanf("%s %d",&right,&n);
	getchar();//吸收换行 
	char temp[100];//输入字符长度可能大于
	while(n--){
		gets(temp);
		if(strcmp(temp,right)==0){
			printf("Welcome in\n");
			flag=1;
			break;
		}
		else if(temp[0]=='#'&&strlen(temp)==1){
			flag=1;
			break;
		}
		else printf("Wrong password: %s\n",temp);
		
	}
	if(flag==0) printf("Account locked");	
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值