题目来源:http://codeforces.com/group/aUVPeyEnI2/contest/229510

时间限制:1s

空间限制:512MB

题目大意:

给定一个字符串,使用%[...]形式将字符串中出现的字符整理到最短和最小(ASCII范围为32~126),可使用的字符有 '-' '^'

题目解法:模拟整理正的和使用 '^' 取反的两个字符串,输出较短较小的那个(注意当所有字符都存在时,输出%[^!]最小)

样例:

代码:

#include <algorithm>
#include <iostream>
#include <cstring>
#include <vector>
#include <cstdio>
#include <string>
#include <cmath>
#include <queue>
#include <set>
#include <map>
#include <complex>
using namespace std;
typedef long long ll;
typedef long double db;
typedef pair<int,int> pii;
typedef vector<int> vi;
#define de(x) cout << #x << "=" << x << endl
#define rep(i,a,b) for(int i=a;i<(b);i++)
#define all(x) (x).begin(),(x).end()
#define sz(x) (int)(x).size()
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define pi acos(-1.0)
#define mem0(a) memset(a,0,sizeof(a))
#define memf(b) memset(b,false,sizeof(b))
#define ll long long
#define eps 1e-10
#define inf 1e17
#define maxn 101010
int main()
{
string str;
bool a[200];
int b[200];
//mem0(str);'
mem0(b);
int tot=0;
for(int i=32;i<=126;i++)
{
char z=(char)i;
if(z==' '||z>='0'&&z<='9'||z>='A'&&z<='Z'||z>='a'&&z<='z')
b[tot++]=i;
}
memf(a);
getline(cin,str);
//cout<<str;
int num=0,num1=0,num2=0,num3=0;
for(int i=0;i<str.size();i++)
{
a[(int)str[i]]=true;
// if(str[i]==' ')num=1;
// if(str[i]>='0'&&str[i]<='9')num1++;
// if(str[i]>='A'&&str[i]<='Z')num2++;
// if(str[i]>='a'&&str[i]<='z')num3++;
}
// for(int i=32;i<=126;i++)
// {
// printf("%c ",i);
// cout<<a[i]<<" ";
// }
int flag=0;
for(int i=0;i<tot;i++)
{
if(a[b[i]]==false)
{
flag=1;
break;
}
}
if(!flag)
{
cout<<"%[^!]"<<endl;
return 0;
}
string ans1="";
for(int i=0;i<tot;i++)
{
int t=i;
while(a[b[t]])
{
t++;
}
if(t-i>=3)
{
ans1+=(char)(b[i]);
ans1+="-";
ans1+=(char)(b[t-1]);
i=t-1;
}
else if(t-i==2)
{
ans1+=(char)(b[i]);
ans1+=(char)(b[i+1]);
i++;
}
else if(t-i==1)
ans1+=(char)b[i];
}
for(int i=0;i<ans1.size();i++)
{
if(ans1[i]=='a'&&ans1[i+1]=='-')
{
ans1[i]='[';
}
if(ans1[i]=='A'&&ans1[i+1]=='-')
{
ans1[i]=':';
}
if(ans1[i]=='0'&&ans1[i+1]=='-')
{
ans1[i]='!';
}
}
// for(int i=0;i<tot;i++)
// cout<<b[i]<<" ";
string ans2="^";
for(int i=0;i<tot;i++)
{
int t=i;
while(a[b[t]]==false&&t<tot)
{
t++;
}
if(t-i>=3)
{
ans2+=(char)(b[i]);
ans2+="-";
ans2+=(char)(b[t-1]);
i=t-1;
}
else if(t-i==2)
{
ans2+=(char)(b[i]);
ans2+=(char)(b[i+1]);
i++;
}
else if(t-i==1)
ans2+=(char)b[i];
}
for(int i=0;i<ans2.size();i++)
{
if(ans2[i]=='a'&&ans2[i+1]=='-')
{
ans2[i]='[';
}
if(ans2[i]=='A'&&ans2[i+1]=='-')
{
ans2[i]=':';
}
if(ans2[i]=='0'&&ans2[i+1]=='-')
{
ans2[i]='!';
}
}
if(ans1.length()==ans2.length())
{
if(ans1<ans2)
{
cout<<"%["<<ans1<<"]"<<endl;
}
else
cout<<"%["<<ans2<<"]"<<endl;
}
else
{
if(ans1.length()<ans2.length())
cout<<"%["<<ans1<<"]"<<endl;
else cout<<"%["<<ans2<<"]"<<endl;
}
return 0;
}

2016-2017 ACM-ICPC, NEERC, Northern Subregional Contest Problem F. Format的更多相关文章

  1. 2013-2014 ACM-ICPC, NEERC, Southern Subregional Contest Problem F. Judging Time Prediction 优先队列

    Problem F. Judging Time Prediction 题目连接: http://www.codeforces.com/gym/100253 Description It is not ...

  2. ACM ICPC 2016–2017, NEERC, Northern Subregional Contest Problem J. Java2016

    题目来源:http://codeforces.com/group/aUVPeyEnI2/contest/229510 时间限制:2s 空间限制:256MB 题目大意: 给定一个数字c 用 " ...

  3. 2016-2017 ACM-ICPC, NEERC, Northern Subregional Contest Problem I. Integral Polygons

    题目来源:http://codeforces.com/group/aUVPeyEnI2/contest/229510 时间限制:2s 空间限制:256MB 题目大意: 给定一个凸多边形,有一种连接两个 ...

  4. 2010-2011 ACM-ICPC, NEERC, Moscow Subregional Contest Problem F. Finance 模拟题

    Problem F. Finance 题目连接: http://codeforces.com/gym/100714 Description The Big Boss Company (BBC) pri ...

  5. 2018-2019 ICPC, NEERC, Southern Subregional Contest

    目录 2018-2019 ICPC, NEERC, Southern Subregional Contest (Codeforces 1070) A.Find a Number(BFS) C.Clou ...

  6. Codeforces 2018-2019 ICPC, NEERC, Southern Subregional Contest

    2018-2019 ICPC, NEERC, Southern Subregional Contest 闲谈: 被操哥和男神带飞的一场ACM,第一把做了这么多题,荣幸成为7题队,虽然比赛的时候频频出锅 ...

  7. 【2015-2016 ACM-ICPC, NEERC, Northern Subregional Contest D】---暑假三校训练

    2015-2016 ACM-ICPC, NEERC, Northern Subregional Contest D Problem D. Distribution in Metagonia Input ...

  8. 模拟赛小结:2015-2016 ACM-ICPC, NEERC, Northern Subregional Contest

    2015-2016 ACM-ICPC, NEERC, Northern Subregional Contest 2019年10月11日 15:35-20:35(Solved 8,Penalty 675 ...

  9. 2015-2016 ACM-ICPC, NEERC, Northern Subregional Contest (9/12)

    $$2015-2016\ ACM-ICPC,\ NEERC,\ Northern\ Subregional\ Contest$$ \(A.Alex\ Origami\ Squares\) 签到 //# ...

随机推荐

  1. css中可以继承的属性

    声明 : 本文源于https://www.cnblogs.com/thislbq/p/5882105.html CSS中可以和不可以继承的属性   一.无继承性的属性 1.display:规定元素应该 ...

  2. laravel5.5源码笔记(五、Pipeline管道模式)

    Pipeline管道模式,也有人叫它装饰模式.应该说管道是装饰模式的一个变种,虽然思想都是一样的,但这个是闭包的版本,实现方式与传统装饰模式也不太一样.在laravel的源码中算是一个比较核心的设计模 ...

  3. T+固定资产二维码管理(生成,打印)

    先 来几句生硬的开场白. 不知不觉中,二维码慢慢的取代了传统的条码.原因之一就是二维码更加的时尚,原因之二便是二维码可以存储更多的信息.......... 企业的固定资产,直接贴个二维码,然后用手机扫 ...

  4. AttributeError: module 'tensorflow' has no attribute 'enable_eager_execution'

    Traceback (most recent call last): File "linear_regression_eager_api.py", line 15, in < ...

  5. ASP.NET底层与各个组件的初步认识与理解 (转载)

    ASP.NET底层的初步认识与理解   最近在国外的网站乱走一通,发现一些比较好的文章,收集整理加于自己的理解,作为笔记形式记录下来,让以后自己有个回忆. ASP.NET是一个非常强大的构建Web应用 ...

  6. .Net 两个对像之间的映射 (一 )

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  7. WEB项目日志分析系统思考

    一.为什么需要日志分析系统 对ETL系统中数据转换和存储操作的相关日志进行记录以及实时分析有助于我们更好的观察和监控ETL系统的相关指标(如单位时间某些操作的处理时间),发现系统中出现的缺陷和性能瓶颈 ...

  8. IAR里面STM32工程使用printf

    1. 首先打开工程的options设置 2. 设置编译器的预宏定义,添加宏定义_DLIB_FILE_DESCRIPTOR 3. 修改文件DLib_Defaults.h DLib_Defaults.h ...

  9. 创龙OMAPL138的SPI FLASH读写

    1. 目前最大的疑问是OMAPL138和DSP6748的DSP部分是完全一样的吗(虽然知道芯片完全是引脚兼容的)?因此现在使用OMAPL138的DSP内核去读写一下外部的SPI FLASH芯片,先看下 ...

  10. Vue视图

    1. 基本模板语法 1.1 插值 文本 数据绑定最常见的形式就是使用“Mustache”语法 (双大括号) 的文本插值 v-text 指令也可以用于数据绑定,如果要更新部分的 textContent ...