B. Help Kingdom of Far Far Away 2
time limit per test

2 seconds

memory limit per test

256 megabytes

input

standard input

output

standard output

For some time the program of rounding numbers that had been developed by the Codeforces participants during one of the previous rounds, helped the citizens of Far Far Away to convert numbers into a more easily readable format. However, as time went by, the economy of the Far Far Away developed and the scale of operations grew. So the King ordered to found the Bank of Far Far Away and very soon even the rounding didn't help to quickly determine even the order of the numbers involved in operations. Besides, rounding a number to an integer wasn't very convenient as a bank needed to operate with all numbers with accuracy of up to 0.01, and not up to an integer.

The King issued yet another order: to introduce financial format to represent numbers denoting amounts of money. The formal rules of storing a number in the financial format are as follows:

  • A number contains the integer part and the fractional part. The two parts are separated with a character "." (decimal point).
  • To make digits in the integer part of a number easier to read, they are split into groups of three digits, starting from the least significant ones. The groups are separated with the character "," (comma). For example, if the integer part of a number equals 12345678, then it will be stored in the financial format as 12,345,678
  • In the financial format a number's fractional part should contain exactly two digits. So, if the initial number (the number that is converted into the financial format) contains less than two digits in the fractional part (or contains no digits at all), it is complemented with zeros until its length equals 2. If the fractional part contains more than two digits, the extra digits are simply discarded (they are not rounded: see sample tests).
  • When a number is stored in the financial format, the minus sign is not written. Instead, if the initial number had the minus sign, the result is written in round brackets.
  • Please keep in mind that the bank of Far Far Away operates using an exotic foreign currency — snakes ($), that's why right before the number in the financial format we should put the sign "$". If the number should be written in the brackets, then the snake sign should also be inside the brackets.

For example, by the above given rules number 2012 will be stored in the financial format as "$2,012.00" and number -12345678.9 will be stored as "($12,345,678.90)".

The merchants of Far Far Away visited you again and expressed much hope that you supply them with the program that can convert arbitrary numbers to the financial format. Can you help them?

Input

The input contains a number that needs to be converted into financial format. The number's notation length does not exceed 100characters, including (possible) signs "-" (minus) and "." (decimal point). The number's notation is correct, that is:

  • The number's notation only contains characters from the set {"0" – "9", "-", "."}.
  • The decimal point (if it is present) is unique and is preceded and followed by a non-zero quantity on decimal digits
  • A number cannot start with digit 0, except for a case when its whole integer part equals zero (in this case the integer parts is guaranteed to be a single zero: "0").
  • The minus sign (if it is present) is unique and stands in the very beginning of the number's notation
  • If a number is identically equal to 0 (that is, if it is written as, for example, "0" or "0.000"), than it is not preceded by the minus sign.
  • The input data contains no spaces.
  • The number's notation contains at least one decimal digit.
Output

Print the number given in the input in the financial format by the rules described in the problem statement.

Sample test(s)
input
2012
output
$2,012.00
input
0.000
output
$0.00
input
-0.00987654321
output
($0.00)
input
-12345678.9
output
($12,345,678.90)
题意:输入一个数,先判断是正数还是负数。
1、如果是正数:先输出一个$,判断如果是整数,从个位开始每三个数之前加一个',' ,最前面不加;如果是小数,整数部分处理方式同整数,小数部分保留2为小数,如果小数位数大于2,则把多余的部分舍弃;
2、如果是负数,负号‘-’不输出,用()代替,其余部分同正数处理方式相同;
代码比较长,但是好理解:
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
int main()
{
char s[104];
int i,j,k,n,m,len,t;
while(gets(s)!=NULL)
{
len=strlen(s);
if(s[0]!='-')
{
printf("$");
if(strchr(s,'.')==NULL)
{
k=len%3;
if(k==0)
{
for(i=0;i<=2;i++)
printf("%c",s[i]);
for(i=3,j=0;i<len;i++)
{
if(j%3==0)
printf(",");
printf("%c",s[i]);
j++;
}
}
else
{
for(i=0;i<=k-1;i++)
printf("%c",s[i]);
for(i=k,j=0;i<len;i++)
{
if(j%3==0)
printf(",");
printf("%c",s[i]);
j++;
}
}
printf(".00");
}
else
{
for(i=0;i<len;i++)
if(s[i]=='.')
{
m=i;
break;
}
k=m%3;
if(k==0)
{
for(i=0;i<=2;i++)
printf("%c",s[i]);
for(i=3,j=0;i<m;i++)
{
if(j%3==0)
printf(",");
printf("%c",s[i]);
j++;
}
printf(".");
n=len-m-1;
if(n>=2)
printf("%c%c",s[m+1],s[m+2]);
else if(n==1)
printf("%c0",s[m+1]);
}
else
{
for(i=0;i<=k-1;i++)
printf("%c",s[i]);
for(i=k,j=0;i<m;i++)
{
if(j%3==0)
printf(",");
printf("%c",s[i]);
j++;
}
printf(".");
n=len-m-1;
if(n>=2)
printf("%c%c",s[m+1],s[m+2]);
else if(n==1)
printf("%c0",s[m+1]);
}
}
}
else
{
printf("($");
if(strchr(s,'.')==NULL)
{
k=(len-1)%3;
if(k==0)
{
for(i=1;i<=3;i++)
printf("%c",s[i]);
for(i=4,j=0;i<len;i++)
{
if(j%3==0)
printf(",");
printf("%c",s[i]);
j++;
}
}
else
{
for(i=1;i<=k;i++)
printf("%c",s[i]);
for(i=k+1,j=0;i<len;i++)
{
if(j%3==0)
printf(",");
printf("%c",s[i]);
j++;
}
}
printf(".00");
}
else
{
for(i=0;i<len;i++)
if(s[i]=='.')
{
m=i;
break;
}
k=(m-1)%3;
if(k==0)
{
for(i=1;i<=3;i++)
printf("%c",s[i]);
for(i=4,j=0;i<m;i++)
{
if(j%3==0)
printf(",");
printf("%c",s[i]);
j++;
}
printf(".");
n=len-m-1;
if(n>=2)
printf("%c%c",s[m+1],s[m+2]);
else if(n==1)
printf("%c0",s[m+1]);
}
else
{
for(i=1;i<=k;i++)
printf("%c",s[i]);
for(i=k+1,j=0;i<m;i++)
{
if(j%3==0)
printf(",");
printf("%c",s[i]);
j++;
}
printf(".");
n=len-m-1;
if(n>=2)
printf("%c%c",s[m+1],s[m+2]);
else if(n==1)
printf("%c0",s[m+1]);
}
}
printf(")");
}
printf("\n");
}
return 0;
}


Codeforce 143B - Help Kingdom of Far Far Away 2的更多相关文章

  1. Constructing Roads In JGShining's Kingdom(HDU1025)(LCS序列的变行)

    Constructing Roads In JGShining's Kingdom  HDU1025 题目主要理解要用LCS进行求解! 并且一般的求法会超时!!要用二分!!! 最后蛋疼的是输出格式的注 ...

  2. 拓扑排序 --- hdu 4948 : Kingdom

    Kingdom Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Sub ...

  3. codeforces 613D:Kingdom and its Cities

    Description Meanwhile, the kingdom of K is getting ready for the marriage of the King's daughter. Ho ...

  4. Codeforce - Street Lamps

    Bahosain is walking in a street of N blocks. Each block is either empty or has one lamp. If there is ...

  5. HDU 4777 Rabbit Kingdom (2013杭州赛区1008题,预处理,树状数组)

    Rabbit Kingdom Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  6. [ACM] hdu 1025 Constructing Roads In JGShining's Kingdom (最长递增子序列,lower_bound使用)

    Constructing Roads In JGShining's Kingdom Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65 ...

  7. Codeforces Round #360 (Div. 1) D. Dividing Kingdom II 并查集求奇偶元环

    D. Dividing Kingdom II   Long time ago, there was a great kingdom and it was being ruled by The Grea ...

  8. HDU 1025 Constructing Roads In JGShining's Kingdom(二维LIS)

    Constructing Roads In JGShining's Kingdom Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65 ...

  9. Codeforce Round #216 Div2

    e,还是写一下这次的codeforce吧...庆祝这个月的开始,看自己有能,b到什么样! cf的第二题,脑抽的交了错两次后过了pretest然后system的挂了..脑子里还有自己要挂的感觉,果然回头 ...

随机推荐

  1. Android XML解析器的问题

    最近在项目中遇到了一个解析XML的问题,我们是用android自带的DOM解析器来解析XML的,但发现了一个android的问题,那就是在2.3的SDK上面,无法解析像<, >, 等字符串 ...

  2. Java byte数据类型详解

    public static String bytes2HexString(byte[] b) { String ret = ""; for (int i = 0; i < b ...

  3. Java多线程-实例解析

    Java多线程实例 3种实现方法Java中的多线程有三种实现方式:1.继承Thread类,重写run方法.Thread本质上也是一个实现了Runnable的实例,他代表一个线程的实例,并且启动线程的唯 ...

  4. QTableWidget表格合并若干问题及解决方法

    Qt提供 QTableWidget作为表格的类以实现表格的基本功能,表格中所装载的每一个单元格由类QTableWidgetItem提供.这是基于表格实现 Qt提供的一个基础类,若想实现定制表格和单元格 ...

  5. 《UNIX环境高级编程》笔记--read函数,write函数,lseek函数

    1.read函数 调用read函数从文件去读数据,函数定义如下: #include <unistd.h> ssize_t read(int filedes, void* buff, siz ...

  6. 数据层交换和高性能并发处理(开源ETL大数据治理工具--KETTLE使用及二次开发 )

    ETL是什么?为什么要使用ETL?KETTLE是什么?为什么要学KETTLE?        ETL是数据的抽取清洗转换加载的过程,是数据进入数据仓库进行大数据分析的载入过程,目前流行的数据进入仓库的 ...

  7. uvc摄像头代码解析7

    13.uvc视频初始化 13.1 uvc数据流控制 struct uvc_streaming_control { __u16 bmHint; __u8 bFormatIndex; //视频格式索引 _ ...

  8. RStudio版本号管理 整合Git

    本文为原创,转载注明出处. 系统环境: win7 x64 R-3.1.0-win.exe RStudio-0.98.507.exe 前置条件:必须拥有github仓库: 如:https://githu ...

  9. Swift - 在界面上生成81个随机红,灰色圆点(SpriteKit游戏开发)

    下面是生成一个“围住神经猫”游戏的初始场景: 1,界面下方会生成9*9共81个圆点,同时圆点内部添加文本标签显示索引 2,默认圆点为灰色,每行随机取两个点变为红色 3,奇数行和偶数行有一定的错位,错位 ...

  10. 一个能够自己主动生成静态库,自己主动安装程序的Makefile

    .PHONY:clean install CC=g++ CFLAGS=-Wall -g BIN=libecho.a INCLUDE=echo SRC=src OBJS=Socket.o Rio.o T ...