社区讨论

听取WA声一片,0分,求dalao帮助

P10470前缀统计参与者 2已保存回复 1

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
1 条
当前快照
1 份
快照标识符
@lwht24rs
此快照首次捕获于
2024/05/22 20:33
2 年前
此快照最后确认于
2024/05/22 22:30
2 年前
查看原帖
CPP
#include <iostream>
using namespace std;
inline int read(){
	char x = getchar();
	int l = 1,d = 0;
	while(!isdigit(x)) l = (x == '-' ? -l : l),x = getchar();
	while(isdigit(x)) d = (d << 1) + (d << 3) + x - 48,x = getchar();
	return l * d;
}
inline void write(int x){
	if(x < 0) putchar('-'),x = -x;
	if(x > 9) write(x / 10);
	putchar(x % 10 + '0');
}
int n,m,ind = 1,trie[30][2000006],b[2000006];
string s;
void insert(string s){
	int p = 1;
	for(int i = 0;i < s.size(); i++){
		char c = s[i] - 'a';
		if(!trie[c][p]) trie[c][p] = ++ind;
		p = trie[c][p];
	}
	b[p] = 1;
}
int query(string s){
	int p = 1,cnt = 0;
	for(int i = 0;i < s.size(); i++){
		char c = s[i] - 'a';
		if(!trie[c][p]) break;
		else cnt += b[trie[c][p]];
		p = trie[c][p];
	}
	return cnt;
}
int main(){
	n = read(),m = read();
	for(int i = 1;i <= n; i++){
		cin >> s;
		insert(s);
	}
	for(int i = 1;i <= m; i++){
		cin >> s;
		write(query(s)),putchar('\n');
	}
	return 0;
}

回复

1 条回复,欢迎继续交流。

正在加载回复...