数字分隔(二)
时间限制:1000 ms | 内存限制:65535 KB
难度:3
输入
多组测试数据(以eof结尾),每行输入一个实数n(n的位数小于100)
输出
输出分隔后的结果
样例输入
0001234567 0.0000 -10005.1645
样例输出
1,234,567.00 0.00 (10,005.16)
描述
在一个遥远的国家,银行为了更快更好的处理用户的订单,决定将一整串的数字按照一定的规则分隔开来,分隔规则如下:
1、实数的整数部分按照每三个数字用逗号分隔开(整数部分的高位有多余的0时,需先将多余的0过滤后,再进行数字分隔,如:0001234567 输出结果为1,234,567.00)
2、小数部分保留两位小数(四舍五入)
3、如果该数是负的,则在输出时需用括号将分隔后的数字括起来,例如:-10005.1645的输出结果为(10,005.16)
这道题注意四舍五入的时候要约分。。。。。。。
比如:输入:999.9999
输出:1000.00
///这破代码我都不想看,写的真吉尔烂(虽然是我自己写的,我看着也觉着恶心)
#include<stdio.h>
#include<iostream>
#include<algorithm>
#include<string.h>
using namespace std;
int main()
{
char a[1200];
memset(a,0,sizeof(a));
while(scanf("%s",a)!=EOF)
{
int f1=0;///表示是否有负号
int f2=-1;///表示小数的位置
int f3=-1;///表示表示第一个非零数字的位置
int len=strlen(a);
for(int i=1;i<6;i++)
{
a[len+i]=0;
}
int f4=-1;///表示是否有数字
for(int i=len;i>=1;i--)
{
a[i]=a[i-1];
}
len++;
a[0]='0';
for(int i=0;i<len;i++)
{
if(a[i]=='.') {f2=i;break;}
}
if(f2==-1||a[f2+3]<'5'){
if(f2==-1)
{
f2=len;
a[f2]='.';
a[f2+1]='0';
a[f2+2]='0';
a[f2+3]='\0';
len=f2+3;
}
else if(f2==len-1)
{
a[f2+1]='0';
a[f2+2]='0';
a[f2+3]='\0';
len=f2+3;
}
else if(f2==len-2)
{
a[f2+2]='0';
a[f2+3]='\0';
len=f2+3;
}
else {
a[f2+3]='\0';
len=f2+3;
}
}
else
{
int t=f2+2;
a[t]++;
while(a[t]=='9'+1)
{
a[t]='0';
if(a[t-1]=='.') t--;
else if(a[t-1]=='-'){
a[t-2]='-'; a[t-1]='0';
}
a[t-1]++;
t--;
}
len=f2+3;
}
f2=-1;
for(int i=0;i<len;i++)
{
if(a[i]=='-') f1=1;
if(a[i]=='.') f2=i;
if(f3==-1&&f2==-1&&a[i]!='0'&&a[i]!='.'&&a[i]!='-')
{
f3=i;
}
}
if(a[f2+1]=='0'&&a[f2+2]=='0'&&f3==-1) f1=0;
if(f1) printf("(");
if(f3!=-1)
{
printf("%c",a[f3++]);
for(;f3<f2;f3++)
{
if((f2-f3)%3==0)
printf(",");
printf("%c",a[f3]);
}
}
else printf("0");
printf(".");
printf("%c",a[f2+1]);
printf("%c",a[f2+2]);
if(f1) printf(")");
//printf(" %c",a[f2+2]);
printf("\n");
}
return 0;
}