1067. 试密码(20) PAT
来源:互联网 发布:flyme远程清除数据 编辑:程序博客网 时间:2024/06/11 19:40
1067. 试密码(20)
时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
CHEN, Yue
当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死。本题就请你实现这个小功能。
输入格式:
输入在第一行给出一个密码(长度不超过20的、不包含空格、Tab、回车的非空字符串)和一个正整数N(<= 10),分别是正确的密码和系统允许尝试的次数。随后每行给出一个以回车结束的非空字符串,是用户尝试输入的密码。输入保证至少有一次尝试。当读到一行只有单个#字符时,输入结束,并且这一行不是用户的输入。
输出格式:
对用户的每个输入,如果是正确的密码且尝试次数不超过N,则在一行中输出“Welcome in”,并结束程序;如果是错误的,则在一行中按格式输出“Wrong password: 用户输入的错误密码”;当错误尝试达到N次时,再输出一行“Account locked”,并结束程序。
输入样例1:Correct%pw 3correct%pwCorrect@PWwhatisthepassword!Correct%pw#输出样例1:
Wrong password: correct%pwWrong password: Correct@PWWrong password: whatisthepassword!Account locked输入样例2:
cool@gplt 3coolman@gpltcoollady@gpltcool@gplttry again#输出样例2:
Wrong password: coolman@gpltWrong password: coollady@gpltWelcome in
#include <cstdio>#include <iostream>#include <string>using namespace std;int main(){string pw;int count;cin>>pw>>count;string trypw;getchar();for(int i=0;i<count;i++){getline(cin,trypw);if(pw.size()!=1&&pw[0]!='#'&&trypw.size()==1&&trypw[0]=='#'){return 0;}if(trypw!=pw){cout<<"Wrong password: "<<trypw<<endl;}else{cout<<"Welcome in"<<endl;return 0;}}cout<<"Account locked"<<endl;return 0;}
这道题的陷阱是,之后尝试的某行密码,可能存在空格。所以读取尝试密码时一定要用getline()。
阅读全文
0 0
- PAT 1067. 试密码(20)
- 1067. 试密码(20) PAT
- PAT 1067. 试密码(20)
- PAT 1067. 试密码(20)-乙级
- 1067. 试密码(20) PAT 乙级
- PAT乙级 1067. 试密码(20)
- PAT乙级 1067. 试密码(20)
- PAT 乙级 1067.试密码(20)
- [PAT乙级]1067. 试密码(20)
- pat 乙级 1067. 试密码(20)
- PAT乙级1067. 试密码(20)
- pat乙级 1067. 试密码(20)
- PAT 乙级1067. 试密码
- [PAT-乙级]1067.试密码
- PAT Basic 1067. 试密码(20)(C语言实现)
- PAT (Basic Level) Practise (中文) 1067. 试密码(20)
- PAT (Basic Level) Practise (中文)1067. 试密码(20)
- 1067. 试密码(20) PAT乙级真题
- iOS[配置篇]下载的demo如何进行真机调试。
- PHP冒泡法排序
- iOS转屏
- MySQL insert into ... select 的锁情况 【转】
- final关键字
- 1067. 试密码(20) PAT
- 机器视觉工业相机选型指导
- Python中奇怪的现象
- 统计数据库表中关键词出现的次数,按次数大小降序排序
- django NoReverseMatch at /xxx
- 多线程系列之生产者和消费者
- sprintf与sscanf函数总结
- 第八章 信号时频分析 ——8.1 信号短时傅里叶变换
- mybatis中的mapping.xml详解