NYOJ题目1092数字分隔

数字分隔(二)

时间限制: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;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值