当前位置: 代码迷 >> 综合 >> PAT乙级 1076 Wifi密码 (15分) 1081 检查密码 (15分)
  详细解决方案

PAT乙级 1076 Wifi密码 (15分) 1081 检查密码 (15分)

热度:17   发布时间:2023-12-17 14:17:10.0

1076 Wifi密码 (15分)

下面是微博上流传的一张照片:“各位亲爱的同学们,鉴于大家有时需要使用 wifi,又怕耽误亲们的学习,现将 wifi 密码设置为下列数学题答案:A-1;B-2;C-3;D-4;请同学们自己作答,每两日一换。谢谢合作!!~”—— 老师们为了促进学生学习也是拼了…… 本题就要求你写程序把一系列题目的答案按照卷子上给出的对应关系翻译成 wifi 的密码。这里简单假设每道选择题都有 4 个选项,有且只有 1 个正确答案。

输入格式:

输入第一行给出一个正整数 N(≤ 100),随后 N 行,每行按照 编号-答案 的格式给出一道题的 4 个选项,T 表示正确选项,F 表示错误选项。选项间用空格分隔。

输出格式:

在一行中输出 wifi 密码。

稍微复杂点的题但是不难

#include<iostream>
#include<vector>
using namespace std;class ans {
public:string a;string b;string c;string d;
};
char call(char s)
{if (s == 'A')return '1';if (s == 'B')return '2';if (s == 'C')return '3';if (s == 'D')return '4';}
int main()
{int sum = 0;cin >> sum;vector<ans> v(sum);vector<char>v1;for (int i = 0; i < sum; i++){cin >> v[i].a >> v[i].b >> v[i].c >> v[i].d;}//cout << v[1].a[2] << " " << v[1].a[0];for (int i = 0; i < sum; i++){if (v[i].a[2] == 'T'){v1.push_back(call(v[i].a[0]));continue;}else if (v[i].b[2] == 'T'){v1.push_back(call(v[i].b[0]));continue;}else if (v[i].c[2] == 'T'){v1.push_back(call(v[i].c[0]));continue;}else{v1.push_back(call(v[i].d[0]));continue;}}for (int i = 0; i < v1.size(); i++){cout << v1[i];}return 0;
}

1081 检查密码 (15分)

本题要求你帮助某网站的用户注册模块写一个密码合法性检查的小功能。该网站要求用户设置的密码必须由不少于6个字符组成,并且只能有英文字母、数字和小数点 .,还必须既有字母也有数字。

输入格式:

输入第一行给出一个正整数 N(≤ 100),随后 N 行,每行给出一个用户设置的密码,为不超过 80 个字符的非空字符串,以回车结束。

输出格式:

对每个用户的密码,在一行中输出系统反馈信息,分以下5种:

  • 如果密码合法,输出Your password is wan mei.
  • 如果密码太短,不论合法与否,都输出Your password is tai duan le.
  • 如果密码长度合法,但存在不合法字符,则输出Your password is tai luan le.
  • 如果密码长度合法,但只有字母没有数字,则输出Your password needs shu zi.
  • 如果密码长度合法,但只有数字没有字母,则输出Your password needs zi mu.

注意这道题有一个很坑的地方,字符串中可能存在空格,所以不能使用一般的scanf或者cin,会使第三个例子出错。

在网上看了很多方法,主要是用gets,但是具体实现和我的方法差别很大,不过好在最后找到了曲线救国的方法。

即:使用getline()函数(这个函数在string的函数库中),但是这样需要在输入我们需要输入密码个数后面加上一个getchar(),防止把回车当做一行

同时网上还有一种使用scanf的方法 scanf(“%[^\n]”,str);

#include<iostream>
#include<vector>
#include<string>
using namespace std;int main()
{int sum = 0;cin >> sum;vector<string> v;getchar();for (int i = 0; i < sum; i++){string temp;//cin >> temp;getline(cin,temp);v.push_back(temp);}for (int i = 0; i < sum; i++){int shuzi = 0,zimu=0,biao=0;int size1 = 0;for (int i1 = 0; i1 < v.size(); i1++){string t = v[i];size1 = t.size();if (size1 < 6){cout << "Your password is tai duan le." << "\n";break;}for (int i2 = 0; i2 < size1; i2++){if ((t[i2] >= 'a' && t[i2] <= 'z') || (t[i2] >= 'A' && t[i2] <= 'Z'))zimu++;else if ((t[i2] >= '0') && (t[i2] <= '9'))shuzi++;else if (t[i2] == '.')biao++;}if (size1 == zimu + shuzi + biao && zimu != 0 && shuzi != 0){cout << "Your password is wan mei." << "\n";break;}if (size1 != zimu + shuzi + biao){cout << "Your password is tai luan le." << "\n";break;}if (shuzi == 0){cout << "Your password needs shu zi." << "\n";break;}if (zimu == 0){cout << "Your password needs zi mu." << "\n";break;}}}return 0;
}

 

  相关解决方案