给出N个字符串恰好由三位字母(大小写)组成,再给出M个查询字符串,问每个查询字符串在N个字符中出现的次数。
2021/4/17 18:25:11
本文主要是介绍给出N个字符串恰好由三位字母(大小写)组成,再给出M个查询字符串,问每个查询字符串在N个字符中出现的次数。,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1 #include<cstdio> 2 const int maxn = 100; 3 char S[maxn][5], temp[5]; 4 int hashTable[52 * 52 * 52 + 10] = {0}; 5 //将52个字母对应到52进制中去。 6 //将A--Z对应到0--25,将a---z可作为26--52. 7 int hashFunc(char s[], int len){ 8 int id = 0; 9 for (int i = 0; i <len; i++) 10 { 11 if(s[i]>='A'&&s[i]<='Z') 12 { 13 id = id * 52 + (s[i] - 'A'); 14 } 15 else if(s[i]>='a'&&s[i]<='z') 16 { 17 id = id * 52 + (s[i] - 'a'); 18 } 19 } 20 return id;//由此返回的十进制的数便与每个字符串一一对应了。 21 } 22 int main() 23 { 24 int n, m; 25 printf("请分别输入两字符串组N与M所含的个数"); 26 scanf("%d%d", &n, &m); 27 for (int i = 0; i < n; i++) 28 { 29 scanf("%s", &S[i]); 30 int id = hashFunc(S[i], 3); 31 hashTable[id]++; 32 } 33 for (int i = 0; i < m; i++)//对于每个M组中的字符串 34 { 35 scanf("%s", temp); 36 int id = hashFunc(temp, 3); 37 printf("%d\n", hashTable[id]); 38 } 39 return 0; 40 }
这篇关于给出N个字符串恰好由三位字母(大小写)组成,再给出M个查询字符串,问每个查询字符串在N个字符中出现的次数。的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-09聊聊如何通过arthas-tunnel-server来远程管理所有需要arthas监控的应用
- 2024-05-09log4j2这么配就对了
- 2024-05-09nginx修改Content-Type
- 2024-05-09Redis多数据源,看这篇就够了
- 2024-05-09Google Chrome驱动程序 124.0.6367.62(正式版本)去哪下载?
- 2024-05-09有没有大佬知道这种数据应该怎么抓取呀?
- 2024-05-09这种运行结果里的10.100000001,怎么能最快改成10.1?
- 2024-05-09企业src漏洞挖掘-有意思的命令执行
- 2024-05-08阿里云域名注册流程,分享给第一次购买域名的新手站长!
- 2024-05-082024年,行业变动下的程序员应该首先学习哪种编程语言?