题目描述
给定一个数,请将该数各个位上数字反转得到一个新数。
这次与NOIp2011普及组第一题不同的是:这个数可以是小数,分数,百分数,整数。整数反转是将所有数位对调;小数反转是把整数部分的数反转,再将小数部分的数反转,不交换整数部分与小数部分;分数反转是把分母的数反转,再把分子的数反转,不交换分子与分母;百分数的分子一定是整数,百分数只改变数字部分。整数新数也应满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数的最高位数字不应为零;小数新数的末尾不为0(除非小数部分除了0没有别的数,那么只保留1个0);分数不约分,分子和分母都不是小数(约分滴童鞋抱歉了,不能过哦。输入数据保证分母不为0),本次没有负数。
【小结】:
没想到这个题目细节也是挺多的,这些水题虽然很水,但是细节还是需要我们去注意,比如如果是小数的话,小数部分必须前后都没有零,去掉前导零记得不要全部去掉了,比如0.02=0.2不要把整数 部分变成空字符串不然就会报错,而且自己不知道哪里出问题了。
#include<bits/stdc++.h>
using namespace std;
const int N=1e4+10;
char s[N],t1[N],t2[N];
void Reverse(char s[],int flag=0){
//printf("S: %s\n",s);
int len=strlen(s);
int cur=0;
for(int i=len-1;i>=0;i--){
if(s[i]=='0'){
s[i]='\0';
}else{
cur=i;break;
}
}
if(!cur&&s[cur]=='\0')
s[cur]='0';
reverse(s,s+cur+1);
if(flag){
len=strlen(s);
for(int i=len-1;i>=0;i--){
if(s[i]=='0'){
s[i]='\0';
}else{
cur=i;break;
}
}
if(!cur&&s[cur]=='\0')
s[cur]='0';
}
}
int main()
{
scanf("%s",s);
int flag=0;
for(int i=0;s[i];i++){
if(s[i]=='.') flag=1,s[i]=' ';
if(s[i]=='/')flag=2,s[i]=' ';
if(s[i]=='%') flag=3,s[i]=' ';
}
//printf("flag: %d\n",flag);
switch(flag){
case 0:
sscanf(s,"%s",t1);
Reverse(t1);
printf("%s\n",t1); break;
case 1:
sscanf(s,"%s %s",t1,t2);
Reverse(t1);Reverse(t2,1);
printf("%s.%s\n",t1,t2);break;
case 2:
sscanf(s,"%s %s",t1,t2);
Reverse(t1);Reverse(t2);
printf("%s/%s\n",t1,t2); break;
case 3:
sscanf(s,"%s ",t1);
Reverse(t1);
printf("%s%%\n",t1); break;
}
return 0;
}