写出一个程序,接受一个由字母、数字和空格组成的字符串,和一个字符,然后输出输入字符串中该字符的出现次数。(不区分大小写字母)
数据范围: 1≤n≤1000 1≤n≤1000
输入描述:
第一行输入一个由字母、数字和空格组成的字符串,第二行输入一个字符(保证该字符不为空格)。
输出描述:
输出输入字符串中含有该字符的个数。(不区分大小写字母)
需要注意的是,这种测试用例:
ABC abc
A
因此不能直接 cin
代码
#include <cstdio>
#include <iostream>
#include <unordered_map>
using namespace std;
int main() {
std::unordered_map<char, int> mp;
string t;
string tmp;
while(cin >> t){
tmp += t;
if(getchar() == '\n'){
break;
}
}
for(int i = 0;i < tmp.size();i++){
if(tmp[i] == ' ') continue;
if(tmp[i] >= 'A' && tmp[i] <= 'Z'){
tmp[i] += 32;
}
if(mp.find(tmp[i]) != mp.end()){
mp[tmp[i]]++;
}else{
mp[tmp[i]] = 1;
}
}
char target;
cin >> target;
if(target >= 'A' && target <= 'Z'){
target += 32;
}
cout << mp[target] << endl;
}
// 64 位输出请用 printf("%lld")
标签:tmp,字符,target,HJ2,次数,字符串,include,输入
From: https://www.cnblogs.com/lihaoxiang/p/18083363