L4-107 检查密码(15分) c++代码

该篇文章描述了一个编程任务,要求编写一个函数来检查用户设置的密码是否符合特定条件,如长度至少6个字符、包含字母和数字,且不能只有小数点。程序通过C++实现,根据输入的密码输出相应的验证结果。

本题要求你帮助某网站的用户注册模块写一个密码合法性检查的小功能。该网站要求用户设置的密码必须由不少于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.

输入样例:

5
123s
zheshi.wodepw
1234.5678
WanMei23333
pass*word.6

输出样例:

Your password is tai duan le.
Your password needs shu zi.
Your password needs zi mu.
Your password is wan mei.
Your password is tai luan le.

 代码:

//#include<iostream>
//#include<cstring>
//#include<cmath>
//#include<algorithm>
//#include<ctype.h>
//#include<stdio.h>
//#include<map>
#include<bits/stdc++.h>
using namespace std;

int main(){
	int n;
	cin>>n;
	getchar();
	string s;
	while(n){
		n--;
		int f1=0,f2=0,f=1;
		getline(cin,s);
		if((int)s.size()<6) cout<<"Your password is tai duan le."<<endl;
		else{
			for(int i=0;i<(int)s.size();i++){
				if(!isalnum(s[i])&&s[i]!='.'){
					f=0;
					cout<<"Your password is tai luan le."<<endl;
					break;
				}
				else if(isalpha(s[i])&&f1==0) f1=1;
				else if(isdigit(s[i])&&f2==0) f2=1;
			}
			if(f&&f1&&!f2) cout<<"Your password needs shu zi."<<endl;
			else if(f&&!f1&&f2) cout<<"Your password needs zi mu."<<endl;
			else if(f&&f1&&f2) cout<<"Your password is wan mei."<<endl;
		}
	}
	return 0;
}

### 问题析 `GESP202312-L4T1 小杨的字典` 是一道字符串处理与映射查询类问题。题目要求根据一个给定的字典,将输入字符串中的单词进行替换,若单词不在字典中,则输出 `"UNK"`。 输入格式包括: - 第一行一个整数 `n` 表示字典条目数量; - 接下来 `n` 行,每行两个字符串,表示英文单词和对应的中文翻译; - 最后一行是待翻译的字符串。 输出要求是将字符串中的每个英文单词替换为对应的翻译,非字母字符原样输出。 ### 解题思路 使用 `map<string, string>` 存储字典,可以实现高效的单词查找与替换。遍历输入字符串时,逐个字符读取,若为字母则拼接成单词,否则触发翻译逻辑。翻译时检查单词是否存在于字典中,并输出对应翻译或 `"UNK"`,非字母字符直接输出[^2]。 ### 示例代码 ```cpp #include <bits/stdc++.h> using namespace std; map<string, string> m; int n; string a, b, s, x; int main() { cin >> n; for (int i = 1; i <= n; i++) { cin >> a >> b; m[a] = b; } cin >> s; for (int i = 0; i < s.size(); i++) { if (s[i] >= 'a' && s[i] <= 'z') { x += s[i]; } else { if (x != "") { if (m.count(x)) { cout << m[x]; } else { cout << "UNK"; } } cout << s[i]; x = ""; } } if (x != "") { if (m.count(x)) { cout << m[x]; } else { cout << "UNK"; } } return 0; } ``` ### 代码说明 - 使用 `map<string, string>` 存储字典条目,便于快速查找对应翻译; - 遍历输入字符串时,使用变量 `x` 拼接连续的字母字符; - 遇到非字母字符时,触发翻译逻辑并输出结果; - 最后检查是否仍有未处理的单词,避免遗漏[^2]。 ### 注意事项 - 字典大小敏感,题目中仅处理小字母; - 输入字符串中单词可能被非字母字符隔,如空格、标点等; - 输出需保持非字母字符原样,翻译后的单词与非字母字符之间无额外空格。 ### 相关问题 1. 如何使用 `map` 实现单词翻译查询? 2. 字符串拼接与隔处理的常见技巧有哪些? 3. 如何处理字符串末尾未触发翻译的单词? 4. C++ 中如何高效处理输入输出流? 5. 如何优化字典查询效率?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值