Codeforce 143B - Help Kingdom of Far Far Away 2
2 seconds
256 megabytes
standard input
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?
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.
Print the number given in the input in the financial format by the rules described in the problem statement.
2012
$2,012.00
0.000
$0.00
-0.00987654321
($0.00)
-12345678.9
($12,345,678.90)
#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的更多相关文章
- Constructing Roads In JGShining's Kingdom(HDU1025)(LCS序列的变行)
Constructing Roads In JGShining's Kingdom HDU1025 题目主要理解要用LCS进行求解! 并且一般的求法会超时!!要用二分!!! 最后蛋疼的是输出格式的注 ...
- 拓扑排序 --- hdu 4948 : Kingdom
Kingdom Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Sub ...
- codeforces 613D:Kingdom and its Cities
Description Meanwhile, the kingdom of K is getting ready for the marriage of the King's daughter. Ho ...
- Codeforce - Street Lamps
Bahosain is walking in a street of N blocks. Each block is either empty or has one lamp. If there is ...
- HDU 4777 Rabbit Kingdom (2013杭州赛区1008题,预处理,树状数组)
Rabbit Kingdom Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- [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 ...
- 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 ...
- 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 ...
- Codeforce Round #216 Div2
e,还是写一下这次的codeforce吧...庆祝这个月的开始,看自己有能,b到什么样! cf的第二题,脑抽的交了错两次后过了pretest然后system的挂了..脑子里还有自己要挂的感觉,果然回头 ...
随机推荐
- Linux下安装配置词典GoldenDict
GoldenDict apt-get install goldendict 安装完成以后,需要自己手动加入字典,增加在线翻译网址(例如,有道,金山等),点击 编辑--dictionaries 完 ...
- NodeJS会是昙花一现吗?
在用了一年以后,我感觉node.js有一点不正确劲.它非常有意思,可是我认为我应该用另外一个视角去审视它. 网络编程真的能够更easy吗? node.js无疑有一些设计很好的地方.前段时间我写了一个性 ...
- sql: DUAL
FROM <<Oracle.Database.11g.SQL>> dual is a table that contains a single row. The followi ...
- 重操JS旧业第八弹:面向对象与继承
js里面没有语言语法层面的继承机制,但这并不意味着js就不能实现继承,利用js属性和方法动态性来模拟实现继承,通过总结大概有如下方法实现: 1 原型链继承 我们知道原型在对象中扮演着重要的角色,函数本 ...
- GreenDAO数据库版本升级
GreenDAO是一款非要流行的android平台上的数据库框架,性能优秀,代码简洁. 初始化数据库模型代码的时候需要使用java项目生成代码,依赖的jar包已经上传到我的资源里了,下载地址如下:ht ...
- Poj 3771 hdu 3405
poj 3771 http://poj.org/problem?id=3771 wiki Prim http://zh.wikipedia.org/wiki/%E6%99%AE%E6%9E%97%E5 ...
- Qt中用正則表達式来推断Text的语种,主要通过推断unicode的编码范围
QString MainWindow::ParseLanguage(QString Text) { if(Text.length()<=0) { return & ...
- 【水】HDU 2099——整除的尾数
来源:点击打开链接 数据范围小,枚举水过就行了……不过要注意格式! #include <iostream> #include <cstring> #include <io ...
- DRP分销系统总结
上个月看完的分销系统的视频,用了漫长的时间看这个项目视频,能安慰自己的是不光是看视频了,还做了很多自己想做的事情,比如驾照拿下来了,比如参加了一些考试,比如讲了一些课程等等.把这个系统的总结总算是补上 ...
- JAVA之成员变量初始化
java中成员变量的初始化,如果是普通成员变量可以赋初值,如果没赋初值,则系统会自动赋初值.而对于局部变量必须手动赋初值. package MyText2; public class MyText1 ...