AT_abc345_c的题解
(一)
首先交换相同字符不改变字符串形态,那么就先统计是否有相同字符。
交换不同字符容易证明不同操作后字符串各不相同。
用前缀和或后缀和维护
(二)
AC 代码。
#include<bits/stdc++.h>
#define int long long
using namespace std;
char ch[1000010];
int vis[1000010][27],ans,n;
signed main(){
scanf("%s",ch+1);
n=strlen(ch+1);
for(int i=1;i<=n;i++){
memcpy(vis[i],vis[i-1],sizeof vis[i]);
vis[i][ch[i]-'a']++;
}
bool op=0;
for(int i=1;i<=n;i++){
int pos=ch[i]-'a';
if(vis[n][pos]>vis[i][pos])op=1;
ans+=n-i-(vis[n][pos]-vis[i][pos]);
}
printf("%lld\n",ans+op);
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探