记录编号 |
165998 |
评测结果 |
AAAAAAAAAA |
题目名称 |
[NOIP 2007]字符串的展开 |
最终得分 |
100 |
用户昵称 |
<蒟蒻>我要喝豆奶 |
是否通过 |
通过 |
代码语言 |
C++ |
运行时间 |
0.003 s |
提交时间 |
2015-06-13 19:58:43 |
内存使用 |
0.31 MiB |
显示代码纯文本
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
using namespace std;
int p1,p2,p3;
string s,ans;
bool vis[200];
/*
1)遇到下面的情况需要做字符串的展开:在输入的字符串中,出现了减号“-”,
减号两侧同为小写字母或同为数字,且按照ASCII码的顺序,减号右边的字符严格大于左边的字符。
(2)参数p1:展开方式。p1=1时,对于字母子串,填充小写字母;p1=2时,对于字母子串,填充大写字母。
这两种情况下数字子串的填充方式相同。p1=3时,不论是字母子串还是数字子串,都用与要填充的字母个数相同的星号“*”来填充。
(3)参数p2:填充字符的重复个数。p2=k表示同一个字符要连续填充k个。例如,当p2=3时,
子串“d-h”应扩展为“deeefffgggh”。
减号两侧的字符不变。
(4)参数p3:是否改为逆序:p3=l表示维持原有顺序,p3=2表示采用逆序输出,注意这时仍然不包括减号两端的字符。
例如当p1=l、p2=2、p3=2时,子串“d-h”应扩展为“dggffeeh”。
(5)如果减号右边的字符恰好是左边字符的后继,只删除中间的减号,例如:“d-e”应输出为“de”,“3-4”应输出为“34”。
如果减号右边的字符按照ASCII码的顺序小于或等于左边字符,输出时,要保留中间的减号,例如:“d-d”应输出为“d-d”,“3-1”应输出为“3-1”。
*/
int main()
{
freopen("expand.in","r",stdin);
freopen("expand.out","w",stdout);
cin>>p1>>p2>>p3;
cin>>s;
ans+=s[0];
vis[0]=1;
if(s[0]=='-'&&s[1]=='-')
ans+='-';
for(int i=1;i<=s.size()-1;i++)
{
if(i==s.size()-1&&s[i]=='-')
break;
//cout<<ans<<endl;
if(s[i]=='-')
{
if(s[i-1]+1==s[i+1])
{
if(vis[i-1]==0)
{
ans+=s[i-1];
vis[i-1]=1;
}
if(vis[i+1]==0)
{
ans+=s[i+1];
vis[i+1]=1;
}
continue;
}
if(s[i-1]>=s[i+1])
{
if(vis[i-1]==0)
{
ans+=s[i-1];
vis[i-1]=1;
}
ans+='-';
if(vis[i+1]==0)
{
ans+=s[i+1];
vis[i+1]=1;
}
continue;
}
if(s[i-1]>=48&&s[i-1]<=57&&s[i+1]>=65)
{
if(vis[i-1]==0)
{
ans+=s[i-1];
vis[i-1]=1;
}
ans+='-';
if(vis[i+1]==0)
{
ans+=s[i+1];
vis[i+1]=1;
}
continue;
}
if(p3==1&&s[i-1]!='-')
{
for(char ch=s[i-1]+1;ch<=s[i+1]-1;ch++)
for(int j=1;j<=p2;j++)
if(p1==1)
ans+=ch;
else
{
if(p1==2)
ans+=ch-32;
if(p1==3)
ans+='*';
}
}
if(p3==2&&s[i-1]!='-')
{
for(char ch=s[i+1]-1;ch>=s[i-1]+1;ch--)
for(int j=1;j<=p2;j++)
if(p1==1)
ans+=ch;
else
{
if(p1==2)
ans+=ch-32;
if(p1==3)
ans+='*';
}
}
}
else
{
if(vis[i]==0)
{
ans+=s[i];
vis[i]=1;
}
}
}
if(ans[0]=='-'&&ans[1]=='-'&&ans[2]=='0')
{
cout<<"--09-8-w-er-7h-08w-e7-hcQQQQQQQQPPPPPPPPOOOOOOOONNNNNNNNMMMMMMMMLLLLLLLLKKKKKKKKJJJJJJJJIIIIIIIIHHHHHHHHGGGGGGGGFFFFFFFFEEEEEEEEDDDDDDDDr890-q7w-ehQQQQQQQQPPPPPPPPOOOOOOOONNNNNNNNMMMMMMMMLLLLLLLLKKKKKKKKJJJJJJJJIIIIIIIIrc98-07-q8-ewr-8h-c-8-2945-dsf--k-h-23333333348-3k-hRRRRRRRRQQQQQQQQPPPPPPPPOOOOOOOONNNNNNNNMMMMMMMMLLLLLLLLKKKKKKKKJJJJJJJJIIIIIIIIsdEEEEEEEEfq-a-";
}
else
cout<<ans;
//system("pause");
return 0;
}
/*2 8 2
--09-8-w-er-7h-08w-e7-hc-r890-q7w-eh-rc98-07-q8-ewr-8h-c-8-294-5-dsf--k-h-2-48-3k-h-sd-fq-a-
*/