hiho一下 第165周#1327 : 分隔相同字符

时间限制:10000ms
单点时限:1000ms
内存限制:256MB
描述
给定一个只包含小写字母‘a‘-‘z‘的字符串 S ,你需要将 S 中的字符重新排序,使得任意两个相同的字符不连在一起。

如果有多个重排后字符串满足条件,输出字典序最小的一个。

如果不存在满足条件的字符串,输出INVALID。

输入
字符串S。(1 ≤ |S| ≤ 100000)

输出
输出字典序最小的答案或者INVALID。

样例输入
aaabc
样例输出
abaca

c语言代码:

#include<stdio.h>
#include<string.h>
char s[100010];
int az[27];

char work(int x,int y,char a)
{
    int i,j,k,l;
    j=0;
    k=y/2;
    l=y%2;
    for(i=0;i<26;i++)
    {
        if(az[i]>k+l)
        {
            return ‘ ‘;
        }else if(az[i]==k+l)
        {
            if(l==1)
            {
                s[x]=i+‘a‘;
                az[i]--;
                return i+‘a‘;
            }
            /*else
            {
                j=0;
                while(az[j]==0 || j+‘a‘==a)j++;
                s[x]=j+‘a‘;
                az[j]--;
                return j+‘a‘;
            }//*/
        }
    }
    j=0;
    while(az[j]==0 || j+‘a‘==a)j++;
    s[x]=j+‘a‘;
    az[j]--;
    return j+‘a‘;
}

int main()
{
    int i,j,k,l,L;
    char c;
    while(gets(s)!=NULL)
    {
        L=l=strlen(s);
        memset(az,0,sizeof(az));
        for(i=0;i<l;i++)az[s[i]-‘a‘]++;
        //for(j=0;j<26;j++)if(az[j]>0)printf("%c%d ",j+‘a‘,az[j]);
        //printf("\n");
        k=0;
        c=‘ ‘;
        for(i=0;i<L;i++)
        {
            c=work(i,l,c);
            l--;
            if(c==‘ ‘)k=1;
            //for(j=0;j<26;j++)if(az[j]>0)printf("%c%d ",j+‘a‘,az[j]);
            //printf("\n");
        }
        if(k==0)printf("%s\n",s);else printf("INVALID\n");
    }
    return 0;
}

c++代码:

#include<iostream>
#include<cstring>

char s[100010];
int letters[27];

using namespace std;

char deal_str(int num,int l,char c)
{
    int max,i,j,k;
    i=l%2;
    max=(l+1)/2;
    for(k=0;k<26;k++){
        if(letters[k]>max){
            return ‘ ‘;
        }else if(letters[k]==max){
            if(i==1){
                s[num]=k+‘a‘;
                letters[k]--;
                return k+‘a‘;
            }
        }
    }
    j=0;
    while(letters[j]==0 || j+‘a‘==c){
        j++;
    }
    s[num]=j+‘a‘;
    letters[j]--;
    return j+‘a‘;
}

int main(){
    int i,n,l,err;
    char c;
    while(cin>>s){
        n=l=strlen(s);
        memset(letters, 0, sizeof(letters));
        for(i = 0; i < n; ++i){
            letters[s[i] - ‘a‘]++;
        }
        err=0;
        c=‘ ‘;
        for(i=0;i<n;i++)
        {
            c=deal_str(i,l,c);
            l--;
            if(c==‘ ‘){
                err = 1;
            }
        }
        if(err==0){
            cout<<s<<endl;
        }else {
            cout<<"INVALID"<<endl;;
        }
    }
    return 0;
}

c语言代码:

#include<stdio.h>
#include<string.h>
char s[100010];
int az[27];

char work(int x,int y,char a)
{
int i,j,k,l;
j=0;
k=y/2;
l=y%2;
for(i=0;i<26;i++)
{
if(az[i]>k+l)
{
return ‘ ‘;
}else if(az[i]==k+l)
{
if(l==1)
{
s[x]=i+‘a‘;
az[i]--;
return i+‘a‘;
}
/*else
{
j=0;
while(az[j]==0 || j+‘a‘==a)j++;
s[x]=j+‘a‘;
az[j]--;
return j+‘a‘;
}//*/
}
}
j=0;
while(az[j]==0 || j+‘a‘==a)j++;
s[x]=j+‘a‘;
az[j]--;
return j+‘a‘;
}

int main()
{
int i,j,k,l,L;
char c;
while(gets(s)!=NULL)
{
L=l=strlen(s);
memset(az,0,sizeof(az));
for(i=0;i<l;i++)az[s[i]-‘a‘]++;
//for(j=0;j<26;j++)if(az[j]>0)printf("%c%d ",j+‘a‘,az[j]);
//printf("\n");
k=0;
c=‘ ‘;
for(i=0;i<L;i++)
{
c=work(i,l,c);
l--;
if(c==‘ ‘)k=1;
//for(j=0;j<26;j++)if(az[j]>0)printf("%c%d ",j+‘a‘,az[j]);
//printf("\n");
}
if(k==0)printf("%s\n",s);else printf("INVALID\n");
}
return 0;
}

c++代码:

#include<iostream>
#include<cstring>

char s[100010];
int letters[27];

using namespace std;

char deal_str(int num,int l,char c)
{
int max,i,j,k;
i=l%2;
max=(l+1)/2;
for(k=0;k<26;k++){
if(letters[k]>max){
return ‘ ‘;
}else if(letters[k]==max){
if(i==1){
s[num]=k+‘a‘;
letters[k]--;
return k+‘a‘;
}
}
}
j=0;
while(letters[j]==0 || j+‘a‘==c){
j++;
}
s[num]=j+‘a‘;
letters[j]--;
return j+‘a‘;
}

int main(){
int i,n,l,err;
char c;
while(cin>>s){
n=l=strlen(s);
memset(letters, 0, sizeof(letters));
for(i = 0; i < n; ++i){
letters[s[i] - ‘a‘]++;
}
err=0;
c=‘ ‘;
for(i=0;i<n;i++)
{
c=deal_str(i,l,c);
l--;
if(c==‘ ‘){
err = 1;
}
}
if(err==0){
cout<<s<<endl;
}else {
cout<<"INVALID"<<endl;;
}
}
return 0;
}

时间: 2024-10-29 19:12:04

hiho一下 第165周#1327 : 分隔相同字符的相关文章

hiho一下 第二十一周(线段树 离散化)

知识点1:离散化  对于这些区间来说,其实并不会在乎具体数值是多少,而是在他们的左右端点之间互相进行比较而已.所以你就把这N个区间的左右端点——2N个整数提出来,处理一下呗?你要注意的是,这2N个数是什么其实并不重要,你可以把这2N个数替换成为任何另外2N个数,只要他们之间的相对大小关系不发生改变就可以.” 解决方法: 那么我需要额外做的事情就是在构建线段树之前对区间进行预处理:将区间的左右端点选出来,组成一个集合,然后将这个集合依次对应到正整数集合上,并且利用这个对应将原来的区间的左右端点更换

hiho一下 第115周:网络流一?Ford-Fulkerson算法 (Edmond-Karp,Dinic,SAP)

来看一道最大流模板水题,借这道题来学习一下最大流的几个算法. 分别用Edmond-Karp,Dinic ,SAP来实现最大流算法. 从运行结过来看明显SAP+当前弧优化+gap优化速度最快.   hiho一下 第115周:网络流一•Ford-Fulkerson算法 原题网址:http://hihocoder.com/contest/hiho115/problem/1 网络流一·Ford-Fulkerson算法 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和

圆内,求离圆心最远的整数点 hiho一下第111周 Farthest Point

1 // 圆内,求离圆心最远的整数点 hiho一下第111周 Farthest Point 2 // 思路:直接暴力绝对T 3 // 先确定x范围,每个x范围内,离圆心最远的点一定是y轴两端的点.枚举x的范围,再比较y 4 // O(n) 5 6 #include <bits/stdc++.h> 7 using namespace std; 8 #define LL long long 9 const double inf = 123456789012345.0; 10 const LL MO

hiho一下 第150周 -- Demo Day (DP)

hiho一下 第150周 -- Demo Day (DP) 题目1 : Demo Day 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 You work as an intern at a robotics startup. Today is your company's demo day. During the demo your company's robot will be put in a maze and without any information

hiho一下第128周 后缀自动机二&#183;重复旋律5

#1445 : 后缀自动机二·重复旋律5 时间限制:10000ms 单点时限:2000ms 内存限制:512MB 描述 小Hi平时的一大兴趣爱好就是演奏钢琴.我们知道一个音乐旋律被表示为一段数构成的数列. 现在小Hi想知道一部作品中出现了多少不同的旋律? 解题方法提示 输入 共一行,包含一个由小写字母构成的字符串.字符串长度不超过 1000000. 输出 一行一个整数,表示答案. 样例输入 aab 样例输出 5 解题方法提示 小Hi:本周的题目其实就是给定一个字符串S,要求出S的所有不同子串的数

Eular质数筛法-hiho一下 第九十三周

Eular质数筛法 hihocoder第九十三周 输入 第1行:1个正整数n,表示数字的个数,2≤n≤1,000,000. 输出 第1行:1个整数,表示从1到n中质数的个数 c++代码 #include <iostream> #include <sstream> #include <fstream> #include <string> #include <vector> #include <deque> #include <qu

Solution: 最近公共祖先&#183;一 [hiho一下 第十三周]

题目1 : 最近公共祖先·一 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho最近发现了一个神奇的网站!虽然还不够像58同城那样神奇,但这个网站仍然让小Ho乐在其中,但这是为什么呢? “为什么呢?”小Hi如是问道,在他的观察中小Ho已经沉迷这个网站一周之久了,甚至连他心爱的树玩具都弃置一边. “嘿嘿,小Hi,你快过来看!”小Ho招呼道. “你看,在这个对话框里输入我的名字,在另一个对话框里,输入你的名字,再点这个查询按钮,就可以查出来……什么!我们居然有同一个

hiho一下 第119周 #1398 : 网络流五&#183;最大权闭合子图 【最小割-最大流--Ford-Fulkerson 与 Dinic 算法】

#1398 : 网络流五·最大权闭合子图 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 周末,小Hi和小Ho所在的班级决定举行一些班级建设活动. 根据周内的调查结果,小Hi和小Ho一共列出了N项不同的活动(编号1..N),第i项活动能够产生a[i]的活跃值. 班级一共有M名学生(编号1..M),邀请编号为i的同学来参加班级建设活动需要消耗b[i]的活跃值. 每项活动都需要某些学生在场才能够进行,若其中有任意一个学生没有被邀请,这项活动就没有办法进行. 班级建设的活

hiho一下 第九十七周 题目1 : 数论六&#183;模线性方程组

传送门 题目1 : 数论六·模线性方程组 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho:今天我听到一个挺有意思的故事! 小Hi:什么故事啊? 小Ho:说秦末,刘邦的将军韩信带领1500名士兵经历了一场战斗,战死四百余人.韩信为了清点人数让士兵站成三人一排,多出来两人:站成五人一排,多出来四人:站成七人一排,多出来六人.韩信立刻就知道了剩余人数为1049人. 小Hi:韩信点兵嘛,这个故事很有名的. 小Ho:我觉得这里面一定有什么巧妙的计算方法!不然韩信不可能