将字符串S映射为一个整数id

点击查看代码
/*
题目:给出N个(N<=100)字符串(由3位大写字母组成),再给出M个查询字符串,问每个查询字符串在N个字符串中出现的次数
输入格式:
n m
第0个字符串
...
第n-1个字符串
第0个查询字符串
...
第m-1个查询字符串

输出格式:
第0个查询字符串出现的次数
...
第m-1个查询字符串出现的次数

输入样例:
5 3
AAA
AAA
BBB
CCC
ABC
AAA
ABC
ABD

输出样例:
AAA出现次数:2
ABC出现次数:1
ABC出现次数:0

题目分析:
1、将字符串映射为一个整数,大写字母A~Z看作数字0~25,将0~25二十六进制转换为0~9十进制,这样就可以将字符串S映射为一个整数
2、将读取的字符串存入S[101][5]中,因为每个字符串由3位组成,列长度可以设置为5。行长度是字符串个数(最多有100个),可以设置为101
   将查询字符串存入temp[5]中
3、将字符串映射存入int hashTable[len]中,下标表示字符串S映射的整数,元素内容是该映射个数(即字符串S出现的次数)
	因为字符串有3位,将26进制->10进制,可以设置len=26*26*26+10
*/

#include<cstdio>
#pragma warning(disable:4996) //允许使用scanf和printf
const int maxn = 101;
char S[maxn][5], temp[5];
int hashTable[26 * 26 * 26 + 10]; //映射表

//映射函数,将字符串S映射为一个整数id
int hashFunc(char S[], int len) {
	int id = 0;
	for (int i = 0; i < len; i++) {
		id = id * 26 + (S[i] - 'A');
	}
	return id;
}

int main() {
	int n, m;
	scanf("%d%d", &n, &m);
	for (int i = 0; i < n; i++) {
		scanf("%s", S[i]);
		int id = hashFunc(S[i], 3); //将字符串S[i]映射为一个整数id,字符串长度3位数
		hashTable[id]++; //id出现的次数存入hashTable[]中
	}
	for (int i = 0; i < m; i++) {
		scanf("%s", temp); //读取m个查询,将要查询的字符串存入temp[]中
		int id = hashFunc(temp, 3);	//将字符串temp映射为一个整数id
		printf("%s出现次数:%d\n", temp, hashTable[id]); //查询该id出现的次数
	}
	return 0;
}

posted @ 2022-09-25 14:04  zhaoo_o  阅读(19)  评论(0编辑  收藏  举报