记录编号 |
418471 |
评测结果 |
AAAAAAAAAA |
题目名称 |
[NOIP 2007]字符串的展开 |
最终得分 |
100 |
用户昵称 |
NVIDIA |
是否通过 |
通过 |
代码语言 |
C++ |
运行时间 |
0.000 s |
提交时间 |
2017-06-30 12:49:13 |
内存使用 |
0.00 MiB |
显示代码纯文本
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define maxn 1010
using namespace std;
int p1,p2,p3,len;
char s[maxn];
char buf[1<<15],*fs,*ft;
inline char getc() {return (fs==ft&&(ft=(fs=buf)+fread(buf,1,1<<15,stdin),fs==ft))?0:*fs++;}
inline int q()
{
long long x=0,f=1; char ch=getc();
while(!isdigit(ch)){if(ch=='-')f=-1;ch=getc();}
while(isdigit(ch)){x=x*10+ch-'0';ch=getc();}return x*f;
}
int Main(){
freopen("expand.in","r",stdin);freopen("expand.out","w",stdout);
scanf("%d%d%d",&p1,&p2,&p3);
scanf("%s",s+1);
len=strlen(s+1);
for(int i=1;i<=len;i++){
if(s[i]!='-'||i==len){
printf("%c",s[i]);
}else{
int data1=(int)(s[i-1]),data2=(int)(s[i+1]);
if(data1+1>=data2){
if(data1+1==data2)continue;
else printf("-");
}else{
if(s[i-1]>='0'&&s[i+1]<='9'){
int sta=s[i-1]-'0',en=s[i+1]-'0';
if(p1==3)for(int j=sta+1;j<en;j++)for(int k=1;k<=p2;k++)printf("*");
else{
if(p3==2) for(int j=en-1;j>sta;j--) for(int k=1;k<=p2;k++) printf("%d",j);
else for(int j=sta+1;j<en;j++) for(int k=1;k<=p2;k++) printf("%d",j);
}
}else if(s[i-1]>='a'&&s[i+1]<='z'){
if(p1==3)for(int j=s[i+1]-1;j>s[i-1];j--)for(int k=1;k<=p2;k++)printf("*");
else{
if(p1==1){
if(p3==2) for(int j=s[i+1]-1;j>s[i-1];j--)for(int k=1;k<=p2;k++)printf("%c",j);
else for(int j=s[i-1]+1;j<s[i+1];j++)for(int k=1;k<=p2;k++)printf("%c",j);
}else{
if(p3==2) for(int j=s[i+1]-1;j>s[i-1];j--)for(int k=1;k<=p2;k++)printf("%c",j-'a'+'A');
else for(int j=s[i-1]+1;j<s[i+1];j++)for(int k=1;k<=p2;k++)printf("%c",j-'a'+'A');
}
}
}else printf("-");
}
}
}
getchar();getchar();
return 0;
}
int aa=Main();
int main(){;}