2023年ICPC亚洲合肥赛区赛 C. Cyclic Substrings

题目

题解

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
// #define int long long
#define ll long long
const int maxn = 6e6 + 5;
const int mod = 998244353;
int fail[maxn];//fail[i]表示i结点代表的回文串的最大回文后缀的编号 
int len[maxn]; //len[i]表示结点i代表的回文串的长度 
int trie[maxn][26], tot = 1;//tot初始为1!!!! 
int cnt[maxn];//结点i代表的回文串出现了多少次
int ind[maxn];
string s;
int get(int x, int i){//x是以s[i-1]结尾的回文串,返回以s[i-1]结尾且s[i-len[x]-1]==s[i]的回文串的对应结点编号 
	while(i - len[x] - 1 < 0 || s[i - len[x] - 1] != s[i]) x = fail[x];
	return x;
}
signed main(){
	int i, j;
	int n;
	cin >> n;
	cin >> s;
	s = s + s;
	int cur = 0;
	int pos, last = 0;
	fail[0] = 1;
	fail[1] = 0;
	len[0] = 0;
	len[1] = -1;
	for(i = 0; i < 2 * n; i++){
		pos = get(cur, i);//cur是以s[i-1]结尾的最大回文串 
		int idx = s[i] - '0';
		if(!trie[pos][idx]){ 
			tot++; 
			int t = get(fail[pos], i);
			fail[tot] = trie[t][idx];
			ind[trie[t][idx]]++;
			trie[pos][idx] = tot;//把新建的结点接在pos下面 
			len[tot] = len[pos] + 2;
			// cnt[tot] = cnt[fail[tot]] + 1;
		}
		cur = trie[pos][idx];
		if(i > n - 1)//只计算以 后半串的字符 结尾的最长回文串,否则会重复
			cnt[cur]++;//结点cur代表的回文串出现了多少次
	}
	
	ll res = 0;
	queue<int> q;
	for(int i = 2; i <= tot; i++){
		// if(len[i] > n) continue;
		if(!ind[i]){
			q.push(i);
		}
	}
	while(!q.empty()){
		int u = q.front();
		q.pop();
		int v = fail[u];
		// if(len[v] > n) continue;
		cnt[v] += cnt[u];//一个回文串出现一次,那么它的回文后缀也出现一次
		if(--ind[v] == 0){
			q.push(v);
		}
	}
	for(int i = 2; i <= tot; i++){
		if(len[i] > n) continue;
		// cout << i << ' ' << len[i] << ' ' << cnt[i] << '\n';
		res = (res + 1LL * len[i] * cnt[i] % mod * cnt[i] % mod) % mod;
	}
	cout << res << '\n';
	return 0;
}
相关推荐
爱睡觉的咋1 分钟前
openGauss × AI:打造一个能识图、能讲解、还能推荐的智慧博物馆导览师
算法
视觉AI25 分钟前
一帧就能“训练”的目标跟踪算法:通俗理解 KCF 的训练机制
人工智能·算法·目标跟踪
2301_795167201 小时前
玩转Rust高级应用 如何理解 Rust 实现免疫数据竞争的关键是Send 和 Sync 这两个 trait
开发语言·算法·rust
Blossom.1181 小时前
AI Agent记忆系统深度实现:从短期记忆到长期人格的演进
人工智能·python·深度学习·算法·决策树·机器学习·copilot
贩卖黄昏的熊1 小时前
数据结构示例代码
数据结构
Q741_1471 小时前
C++ 面试高频考点 链表 迭代 递归 力扣 25. K 个一组翻转链表 每日一题 题解
c++·算法·链表·面试·递归·迭代
_fairyland2 小时前
数据结构 力扣 练习
数据结构·考研·算法·leetcode
Neil今天也要学习2 小时前
永磁同步电机无速度算法--基于三阶LESO的反电动势观测器
算法·1024程序员节
机器学习之心2 小时前
NGO-VMD北方苍鹰算法优化变分模态分解+皮尔逊系数+小波阈值降噪+信号重构,MATLAB代码
算法·matlab·重构·信号重构·ngo-vmd·皮尔逊系数·小波阈值降噪
橘颂TA2 小时前
【剑斩OFFER】算法的暴力美学——山脉数组的蜂顶索引
算法·leetcode·职场和发展·c/c++