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的挂了..脑子里还有自己要挂的感觉,果然回头 ...
随机推荐
- Cocos2d-x使用android拍照功能加载照片内存过大,通过另存照片尺寸大小解决
使用2dx调用android拍照功能,拍照结束后在2dx界面显示拍照照片,如果不对照片做处理,会出现内存过大的问题,导致程序崩溃,如果仅仅另存拍照照片,则照片质量大小均下降,导致照片不够清晰,后来发现 ...
- WCF技术剖析之十三:序列化过程中的已知类型(Known Type)
原文:WCF技术剖析之十三:序列化过程中的已知类型(Known Type) [爱心链接:拯救一个25岁身患急性白血病的女孩[内有苏州电视台经济频道<天天山海经>为此录制的节目视频(苏州话) ...
- JS实现图片翻书效果
picture.html <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http- ...
- 基于visual Studio2013解决C语言竞赛题之1010计算
题目 解决代码及点评 /************************************************************************/ ...
- VC2008下使用OpenSSL 1.0.0g(免编译)
OpenSSL整个软件包大概可以分成三个主要的功能部分:密码算法库.SSL协议库以及应用程序. 官网:http://www.openssl.org/OpenSSL for Windows:http:/ ...
- js点击button按钮跳转到另一个新页面
点击按钮怎么跳转到另外一个页面呢?我们在网站制作中可能是需要的,因为有时我们需要做这样的效果,尤其是将按钮做成一个图片,而点击图片要跳转到新的页面时,怎么做到呢? 这样的效果可以:onclick=&q ...
- sum(case when then)(男女生的个数)
判断类似一个班级的男生和女生的人数,用sum (cese when then ) select count(er.execute_result), sum(case er.execute_result ...
- dos批量替换当前目录后缀名
有时候有些后缀名不满足条件,就需要进行批量的替换,如果人为的去替换,那么如果量少的话还好说,量多的话一个个去替换就太傻了,今天从网络上面查找了一些批量替换的dos命令,用起来还挺好用的,就直接把代码贴 ...
- mysql出现Waiting for table metadata lock的原因及解决方案
最近经常遇到mysql数据库死锁,郁闷死, show processlist; 时 Waiting for table metadata lock 能一直锁很久 下面有官网的一段话,可以理解下 htt ...
- JS - 跳转页面
<!-- 第一种: --> <script type="text/javascript"> window.location.href = "log ...