CodeForces 600C【构造】
2024-08-21 02:40:00
题意:
在原字符串中修改数量最少,然后保证最小字典序。
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const int N=2e5+10;
int a[100];
char s[N];
char ans[N];
int main()
{
scanf("%s",s);
int len=strlen(s);
memset(a,0,sizeof(a));
if(len%2==0)
{
for(int i=0;i<len;i++)
{
int x=s[i]-'a';
a[x]++;
}
for(int i=0;i<26;i++)
{
if(a[i]%2)
{
for(int j=25;j>i;j--)
{
if(a[j]%2)
{
a[j]--;
a[i]++;
break;
}
}
}
}
int s=0;
int t=len-1;
for(int i=0;i<26;i++)
{
if(a[i]&&a[i]%2==0)
{
while(a[i])
{
ans[s++]=i+'a';
ans[t--]=i+'a';
a[i]-=2;
}
}
}
ans[len]='\0';
printf("%s\n",ans);
}
else
{
for(int i=0;i<len;i++)
{
int x=s[i]-'a';
a[x]++;
}
for(int i=0;i<26;i++)
{
if(a[i]%2!=0)
{
for(int j=25;j>i;j--)
{
if(a[j]&&a[j]%2!=0)
{
a[j]--;
a[i]++;
break;
}
}
}
}
int s=0;
int t=len-1;
for(int i=0;i<26;i++)
{
if(a[i]&&a[i]%2==0)
{
while(a[i]>0)
{
a[i]-=2;
ans[s++]=i+'a';
ans[t--]=i+'a';
}
}
if(a[i]&&a[i]%2!=0)
{
while(a[i]>1)
{
a[i]-=2;
ans[s++]=i+'a';
ans[t--]=i+'a';
}
ans[len/2]=i+'a';
}
}
ans[len]='\0';
printf("%s\n",ans);
}
return 0;
}
最新文章
- MySQL 常用函数和语句笔记
- js 获取样式兼容方法
- 使用JavaScript创建我的分页
- eval 如何定义函数
- “System.FormatException”类型的异常在 mscorlib.dll 中发生,但未在用户代码中进行处理 其他信息: 该字符串未被识别为有效的 DateTime。
- Jquery结合datagrid框架
- 从花式swap引出的pointer aliasing问题
- ADO.NET调用存储过程
- iOS在GitHub Top 前100 简介
- Mac 电脑前端环境配置
- 模拟ES6中的Promise实现,让原理一目了然
- sgu438-The_Glorious_Karlutka_River
- IdentityServer4【QuickStart】之使用ClientCredentials流程保护API
- 使用 LaTeX 画图系列
- 深入了解HBASE架构(转)
- HighCharts插件学习(二)
- vc++使用IWinHttpRequest获取网页内容乱码
- RAC初步使用
- java-jmx使用
- 在selenium中使用css选择器进行元素定位