7-15 QQ帐户的申请与登陆 (25 分)(map做法+思路分析)

一:题目

实现QQ新帐户申请和老帐户登陆的简化版功能。最大挑战是:据说现在的QQ号码已经有10位数了。

输入格式:
输入首先给出一个正整数N(≤10
​5
​​ ),随后给出N行指令。每行指令的格式为:“命令符(空格)QQ号码(空格)密码”。其中命令符为“N”(代表New)时表示要新申请一个QQ号,后面是新帐户的号码和密码;命令符为“L”(代表Login)时表示是老帐户登陆,后面是登陆信息。QQ号码为一个不超过10位、但大于1000(据说QQ老总的号码是1001)的整数。密码为不小于6位、不超过16位、且不包含空格的字符串。

输出格式:
针对每条指令,给出相应的信息:

1)若新申请帐户成功,则输出“New: OK”;
2)若新申请的号码已经存在,则输出“ERROR: Exist”;
3)若老帐户登陆成功,则输出“Login: OK”;
4)若老帐户QQ号码不存在,则输出“ERROR: Not Exist”;
5)若老帐户密码错误,则输出“ERROR: Wrong PW”。

输入样例:
5
L 1234567890 myQQ@qq.com
N 1234567890 myQQ@qq.com
N 1234567890 myQQ@qq.com
L 1234567890 myQQ@qq
L 1234567890 myQQ@qq.com
输出样例:
ERROR: Not Exist
New: OK
ERROR: Exist
ERROR: Wrong PW
Login: OK

二:思路分析

本题又用到了map容器,既然用到了容器,我们就会考虑该如何 往容器里赋值吧,然后再考虑容器当中的值该如何利用才能符合题意。我用的数组往其中赋值,赋值的对象为 容器当中 未出现过的号码(指的是新用户),然后在’L’操作中 看输入的号码是否在容器中出现过 ,出现过说明这是一个已经申请好的号码,如果没有则输出”ERROR: Not Exist“;如果出现过,然后在比较密码的正确性。

三:上码

#include<bits/stdc++.h>
using namespace std;int main(){int N;cin >> N;map<string,string>m;map<string,string>::iterator t;for( int i = 0; i < N; i++ ){char p1;string str1,str2;cin >> p1 >> str1 >> str2; t = m.find(str1);//t就相当于C里面的指针 if(p1 == 'N'){if( t == m.end()){m[str1] = str2;//将新号码装进容器当中 cout << "New: OK" << endl;	}else{cout << "ERROR: Exist" << endl;	}	}if(p1 == 'L'){if(t == m.end()){cout << "ERROR: Not Exist" << endl;}else{if(m[str1] == str2)//这是 又输入的密码 和 map容器当中存进去的进行比较  cout << "Login: OK" << endl;elsecout << "ERROR: Wrong PW" << endl;  }}}	
}

在这里插入图片描述

另一种做法:

但pta的最后一个点过不去
我自己用的测试例子:
专门测试最后一个测试点,输出都正确 ``
4
N 1234567890 myQQ@qq.com
L 1234567890 myQQ@qq.com
N 1234567891 myQQ@qq.cop
L 1234567891 myQQ@qq.cop

4
N 1234567890 myQQ@qq.com
N 1234567891 myQQ@qq.cop
L 1234567891 myQQ@qq.cop
L 1234567890 myQQ@qq.com

//如果第一个用户为老用户 则必定不存在  直到遇见新用户后 再调用 L 时考虑 其密码的规范性 来判断其是否存在#include<bits/stdc++.h>
using namespace std;void New_Old(vector<char>&v1,vector<int>&v2,vector<string>&v3){int flag = 0,m = -1,n;vector<int>p1;//创建一个容器 存正确的号码vector<string>p2;  for( int i = 0; i < v1.size(); i++ ){if(v1[i] == 'N' && flag == 0) //记录下正确的号码和密码 {m = i;flag = 1; p1.push_back(v2[m]); //将正确申请好的 号码 和 密码 存进容器当中 p2.push_back(v3[m]);//   cout << "New: OK" << endl;      	}else if( v1[i] == 'N' ) //后面又遇到了 N {if(v2[i] == v2[m])cout << "ERROR: Exist" << endl;	 } //出现新的号码时 if(  v2[i+1] != v2[m]  )  {flag = 0;} if(v1[i] == 'L'){if(!p1.empty()  ){//挑选出 已经申请好的 号码  for( int k1 = 0; k1 < p1.size(); k1++){if(v2[i] == p1[k1]){n = k1;break;}}if( v2[i] == p1[n])//老的号码和以前申请的号码相同  接下来比较 密码输入的正确性 和 规范性 {string str = v3[i];string str1 = p2[n];//标准的密码 int temp1 = 0;//判断是否有 空格for( int j = 0; j < str.size(); j++ ){if(str[j] == ' ')temp1 = 1;} if(str.size() < 6 && str.size() > 16){cout << "ERROR: Wrong PW" << endl;	}else if( temp1 == 1 ){cout << "ERROR: Wrong PW" << endl;}else if( str1 != str ){cout << "ERROR: Wrong PW" << endl;}else{cout << "Login: OK" << endl;}} }else  //老号码还没有申请 {cout << "ERROR: Not Exist" << endl; }   }}
}int main(){int N;vector<char>v1;vector<int>v2;vector<string>v3;cin >> N;for(int i = 0; i < N; i++ ){char temp1;int temp2;string temp3;cin >> temp1 >> temp2 >> temp3;v1.push_back(temp1);v2.push_back(temp2);v3.push_back(temp3);}New_Old(v1,v2,v3);}4
N 1234567890 myQQ@qq.com
L 1234567890 myQQ@qq.com
N 1234567891 myQQ@qq.cop
L 1234567891 myQQ@qq.cop

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/308531.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[Redis6]新数据类型_HyperLogLog

HyperLogLog 简介 在工作当中&#xff0c;我们经常会遇到与统计相关的功能需求&#xff0c;比如统计网站PV&#xff08;PageView页面访问量&#xff09;,可以使用Redis的incr、incrby轻松实现。 但像UV&#xff08;UniqueVisitor&#xff0c;独立访客&#xff09;、独立IP数…

每天都在支付,你真的了解信息流和资金流?

作为一个财务类的产品经理&#xff0c;除了每天被财务“虐待”千百遍&#xff0c;还需要对整个资金流向很清楚&#xff1a;钱给谁&#xff0c;怎么给&#xff0c;怎么做逆向流程&#xff0c;谁参与容错等。财务很在意资金的流转安全&#xff0c;但又极不愿意花时间关注它。诸如…

mysql改表字段类型导致数据丢失_故障分析 | 记一次 MySQL 主从双写导致的数据丢失问题【转】...

一、问题起源不久前用户反馈部门的 MySQL 数据库发生了数据更新丢失。为了解决这个问题&#xff0c;当时对用户使用的场景进行了分析。发现可能是因为用户在两台互为主从的机器上都进行了写入导致的数据丢失。如图所示&#xff0c;是正常和异常情况下应用写入数据库的示例。随后…

[Redis6]新数据类型_Geospatial

Geospatial 简介 Redis 3.2 中增加了对GEO类型的支持。GEO&#xff0c;Geographic&#xff0c;地理信息的缩写。该类型&#xff0c;就是元素的2维坐标&#xff0c;在地图上就是经纬度。redis基于该类型&#xff0c;提供了经纬度设置&#xff0c;查询&#xff0c;范围查询&…

《Apache SkyWalking实战》送书活动结果公布

截至2020.07.31 本次送书活动 这么多Apache顶级项目&#xff0c;SkyWalking为何一枝独秀&#xff1f;&#xff0c;本次很多同学在看到活动的书&#xff0c;自行就到网上购买了书。下面把Top 8的留言截图给大家回顾一下。以下8位同学将获赠书籍一本&#xff1a;landon、田晓青、…

7-16 一元多项式求导 (20 分)(详解+题目分析)

7-16 一元多项式求导 (20 分) 1&#xff1a;题目 设计函数求一元多项式的导数。 输入格式: 以指数递降方式输入多项式非零项系数和指数&#xff08;绝对值均为不超过1000的整数&#xff09;。数字间以空格分隔。 输出格式: 以与输入相同的格式输出导数多项式非零项的系数和…

[MyBatisPlus]通用枚举

通用枚举 数据库表添加字段sex 创建通用枚举类型 package com.xxxx.mybatisplus.enums;import com.baomidou.mybatisplus.annotation.EnumValue; import lombok.Getter;Getter public enum SexEnum {MALE(1,"男"),FEMALE(2,"女");EnumValue // 将注解所标…

信创产业发展应不忘初心牢记使命

受国际大环境影响&#xff0c;信创市场国产化替代步伐已然加速。由于其中存在巨大的商机&#xff0c;信创市场中已然出现一些乱象。有的厂商拿洋技术标榜和宣传自主&#xff1b;有的厂商全国各地跑马圈地建产业园&#xff0c;进而向当地政府要政策要市场&#xff1b;有的厂商恶…

mysql采用 级触发_Mysql高级之触发器(trigger)

触发器是一类特殊的事务 ,可以监视某种数据操作(insert/update/delete),并触发相关操作(insert/update/delete)。看以下事件&#xff1a;完成下单与减少库存的逻辑Insert into o (gid,num) values (2,3); // 插入语句Update g set goods_num goods_num - 3 where id 2;// 更新…

[MyBatisPlus]代码生成器

代码生成器 引入依赖 <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-generator</artifactId><version>3.5.1</version></dependency><dependency><groupId>org.freemarker</groupId…

飞机游戏项目完整代码(详解JAVA300集)

一&#xff1a;简介 这是一个可以通过键盘移动飞机位置 然后可以躲避 炮弹的打击 &#xff0c;游戏结束为 当炮弹与飞机发生碰撞 则 最后显示出飞机存活的时长 代表游戏结束 二&#xff1a;上码 1&#xff1a;运行游戏的类 package src.src.cn.wyj.飞机;import java.awt.Co…

[MyBatisPlus]模拟多数据源环境及测试

模拟多数据源环境 多数据源 适用于多种场景&#xff1a;纯粹多库、 读写分离、 一主多从、 混合模式等 目前我们就来模拟一个纯粹多库的一个场景&#xff0c;其他场景类似 场景说明&#xff1a; 我们创建两个库&#xff0c;分别为&#xff1a;mybatis_plus&#xff08;以前…

生活有哪些残忍的真相?

1.很多人拼尽全力&#xff0c;只是为了艰难的生存。2.大多数人一点也不喜欢读书&#xff0c;只是喜欢被别人贴上“爱读书”的标签罢了。3.你越没能力&#xff0c;社交圈质量就越低&#xff0c;碰到的傻逼就越多。4.职场绝不能追求快乐&#xff0c;只能追求痛苦的成长。5.抬起头…

7-17 汉诺塔的非递归实现 (25 分)(思路分析)

一&#xff1a;题目 借助堆栈以非递归&#xff08;循环&#xff09;方式求解汉诺塔的问题&#xff08;n, a, b, c&#xff09;&#xff0c;即将N个盘子从起始柱&#xff08;标记为“a”&#xff09;通过借助柱&#xff08;标记为“b”&#xff09;移动到目标柱&#xff08;标记…

[MyBatisPlus]MyBatisX插件

MyBatisX插件 MyBatis-Plus为我们提供了强大的mapper和service模板&#xff0c;能够大大的提高开发效率 但是在真正开发过程中&#xff0c;MyBatis-Plus并不能为我们解决所有问题&#xff0c;例如一些复杂的SQL&#xff0c;多表联查&#xff0c;我们就需要自己去编写代码和SQ…

7-19 求链式线性表的倒数第K项 (20 分)(思路分析+极简代码+超容易理解)

一&#xff1a;题目描述&#xff1a; 给定一系列正整数&#xff0c;请设计一个尽可能高效的算法&#xff0c;查找倒数第K个位置上的数字。 输入格式: 输入首先给出一个正整数K&#xff0c;随后是若干非负整数&#xff0c;最后以一个负整数表示结尾&#xff08;该负数不算在序…

很认真地聊一下 “选择比努力更重要”

这是头哥侃码的第211篇原创两周前&#xff0c;蚂蚁集团官宣上市计划&#xff0c;在科创板和港交所寻求同步上市的消息&#xff0c;刷爆了朋友圈。消息爆出的第二天&#xff0c;我就看到在某个微信群里的一位 “热心” 小伙伴给他在蚂蚁金服的朋友算了一笔账&#xff0c;说是能套…

Java计算时间差_传统的SimpleDateFormat类

Java计算时间差_传统的SimpleDateFormat类 SimpleDateFormat simpleFormat new SimpleDateFormat("yyyy-MM-dd HH:mm");/*天数差*/Date fromDate1 simpleFormat.parse("2022-03-23 12:00");Date toDate1 simpleFormat.parse("2022-03-23 13:00&qu…

使用神经网络进行稀疏采样_使用python+opencv进行神经网络迁移

梵高画作什么是神经网络的风格迁移&#xff0c;简单来件就是输入1张照片(自己的照片)&#xff0c;输出具备另外一张照片(例子梵高画作)风格的图片&#xff0c;同时保留原本自己图片的元素&#xff0c;如下图片表明了神经网络风格迁移的过程&#xff0c;当然你也可以使用自己的神…