数字分隔(二)
时间限制:
1000 ms | 内存限制:
65535 KB
难度:
3
-
描述
-
在一个遥远的国家,银行为了更快更好的处理用户的订单,决定将一整串的数字按照一定的规则分隔开来,分隔规则如下:
1、实数的整数部分按照每三个数字用逗号分隔开(整数部分的高位有多余的0时,需先将多余的0过滤后,再进行数字分隔,如:0001234567 输出结果为1,234,567.00)
2、小数部分保留两位小数(四舍五入)
3、如果该数是负的,则在输出时需用括号将分隔后的数字括起来,例如:-10005.1645的输出结果为(10,005.16)
-
输入
-
多组测试数据,每行输入一个实数n(n的位数小于100)
输出
-
输出分隔后的结果
样例输入
0001234567
0.0000
-10005.1645
样例输出
1,234,567.00
0.00
(10,005.16)
我想不到简单的方法,只有用if对数据的出现情况做出各种判断,做题过程中一直疏漏特殊情况,一直添加判断条件,所以到最后这个代码有100多行,虽然搞了将近一天才弄出来,但是看到AC还是很开心的~~come on~~
#include <iostream> #include <cstring> using namespace std; int main() { char s[110],t[110],r[110]; while(cin>>s) { memset(r,'\0',sizeof(r)); memset(t,'\0',sizeof(t)); int i,l,poi=0,dis,car,k=0,f=1,j=0; l=strlen(s); for(i=s[0]=='-'?1:0; i<l; i++)//处理原字符串 { if(s[i]!='0'&&f) { if(s[i]=='.') t[j++]='0'; f=0; } if(s[i]=='0'&&f) continue; else t[j++]=s[i]; } if(!j) { t[j++]='0';f=0;//判断当原字符串为0时的情况 } for(i=0; i<j; i++) { if(t[i]=='.') { poi=i;//找出小数点的位置 f=1;//如果有小数点,则f置1 break; } } if(f)//当字符串有小数点时 { dis=j-1-poi;//计算小数点到字符串末尾的距离 if(dis==2) for(i=j-1; i>=0; i--)r[k++]=t[i];//如果只有两位小数,原样输出 else if(dis==1)//如果有一位小数,则最后一位补0 { r[k++]='0'; for(i=j-1; i>=0; i--) r[k++]=t[i]; } else//如果距离大于2 { if(t[poi+3]<'5') for(i=poi+2; i>=0; i--)r[k++]=t[i];//如果第三位小数小于5 else//如果第三位小数大于5 { car=1; for(i=poi+2; i>=0; i--) { if(t[i]=='.') { r[k++]=t[i]; continue; } if(car) t[i]+=1; if(t[i]>'9') { t[i]='0'; car=1; } else car=0; r[k++]=t[i]; } if(t[0]=='0') r[k++]='1'; } } } else for(i=j-1; i>=0; i--)r[k++]=t[i];//没有小数点,原样输出 if(s[0]=='-')//如果是负数 { if(!f) { cout<<'(';//负数需要在字符串前后加上括号 for(i=k-1; i>=0; i--) { cout<<r[i]; if(i%3==0&&i) cout<<',';//控制','的位置 } cout<<".00"<<')'<<endl;//没有小数点,补上小数点和两位零 } else { cout<<'('; for(i=k-1; i>=0; i--) { cout<<r[i]; if(i%3==0&&i>3) cout<<','; } cout<<')'<<endl; } } else { if(!f) { for(i=k-1; i>=0; i--) { cout<<r[i]; if(i%3==0&&i) cout<<','; } cout<<".00"<<endl; } else { for(i=k-1; i>=0; i--) { cout<<r[i]; if(i%3==0&&i>3) cout<<','; } cout<<endl; } } } }
-
多组测试数据,每行输入一个实数n(n的位数小于100)