社区讨论

wrong answer Too short on line 1

P1098[NOIP 2007 提高组] 字符串的展开参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@mi7uulwh
此快照首次捕获于
2025/11/21 03:59
4 个月前
此快照最后确认于
2025/11/21 03:59
4 个月前
查看原帖
CPP
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
	int p1,p2,p3;
	char s[103];
	int len;
bool aph(char ch){
	return 'a'<=ch&&ch<='z';
}
bool num(char ch){
	return '0'<=ch&&ch<='9';
}
bool valid(char ch){
	return aph(ch)||num(ch)||ch=='-';
}
bool err(char a,char b){
	if(aph(a))
		return num(b);
	if(num(b))
		return aph(a);
	return 1;
}
int main(){
	freopen("data.in","r",stdin);
	freopen("data.out","w",stdout);
	scanf("%d%d%d",&p1,&p2,&p3);	getchar();
	len=0;
	while(valid(s[len]=getchar()))
		len++;
	for(int i=0;i<len;i++)
		if(i==0||i==len-1||s[i]!='-')
			printf("%c",s[i]);
		else 
			if(s[i-1]>=s[i+1]
				||err(s[i-1],s[i+1]))
				printf("-");
			else 
			if(s[i+1]==s[i-1]+1)
				continue;
			else 
				if(p3==1){
					if(p1==1)
						for(char j=s[i-1]+1;j<s[i+1];j++)
							for(int k=1;k<=p2;k++)
								printf("%c",j);
					else 
					if(p1==2){
						if(aph(s[i-1]))
						for(char j=s[i-1]+1;j<s[i+1];j++)
							for(int k=1;k<=p2;k++)
								printf("%c",j-'a'+'A');
						else 
						for(char j=s[i-1]+1;j<s[i+1];j++)
							for(int k=1;k<=p2;k++)
								printf("%c",j);
					}
					else 
						for(char j=s[i-1]+1;j<s[i+1];j++)
							for(int k=1;k<=p2;k++)
								printf("*");
				}
				else {
					if(p1==1)
						for(char j=s[i+1]-1;j>s[i-1];j--)
							for(int k=1;k<=p2;k++)
								printf("%c",j);
					else 
					if(p1==2){
						if(aph(s[i-1]))
						for(char j=s[i+1]-1;j>s[i-1];j--)
							for(int k=1;k<=p2;k++)
								printf("%c",j-'a'+'A');
						else 
						for(char j=s[i+1]-1;j>s[i-1];j--)
							for(int k=1;k<=p2;k++)
								printf("%c",j);
					}
					else 
						for(char j=s[i+1]-1;j>s[i-1];j--)
							for(int k=1;k<=p2;k++)
								printf("*");
				}
	printf("\n");	
	return 0;
}

得到0分。。。
本题对输出有什么特殊要求吗?

回复

2 条回复,欢迎继续交流。

正在加载回复...