HDU 2054
2015-01-24 18:37
309 查看
期末考终于结束了,没有挂科的、继续更新。
Total Submission(s): 68679 Accepted Submission(s): 10699
[align=left]Problem Description[/align]
Give you two numbers A and B, if A is equal to B, you should print "YES", or print "NO".
[align=left]Input[/align]
each test case contains two numbers A and B.
[align=left]Output[/align]
for each case, if A is equal to B, you should print "YES", or print "NO".
[align=left]Sample Input[/align]
1 2
2 2
3 3
4 3
[align=left]Sample Output[/align]
NO
YES
YES
NO
[align=left]Author[/align]
8600 && xhd
[align=left]Source[/align]
校庆杯Warm Up
就是判断两个数是否相等,一开始以为很简单,但是是高精度的,比如3.0000000000000000000000000000000000000000等于3。计算机是无法精确的表示小数点那么多位的,所以普通的相等不行,必须用字符串做,只要把没用的0去掉就好了。然后用strcmp函数比较。
上代码
A == B ?
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 68679 Accepted Submission(s): 10699
[align=left]Problem Description[/align]
Give you two numbers A and B, if A is equal to B, you should print "YES", or print "NO".
[align=left]Input[/align]
each test case contains two numbers A and B.
[align=left]Output[/align]
for each case, if A is equal to B, you should print "YES", or print "NO".
[align=left]Sample Input[/align]
1 2
2 2
3 3
4 3
[align=left]Sample Output[/align]
NO
YES
YES
NO
[align=left]Author[/align]
8600 && xhd
[align=left]Source[/align]
校庆杯Warm Up
就是判断两个数是否相等,一开始以为很简单,但是是高精度的,比如3.0000000000000000000000000000000000000000等于3。计算机是无法精确的表示小数点那么多位的,所以普通的相等不行,必须用字符串做,只要把没用的0去掉就好了。然后用strcmp函数比较。
上代码
#include <stdio.h> #include <string.h> int main() { char s[100000]; char s1[100000]; int i,l,l1,flag,flag1; while(~scanf("%s%s",s,s1)) { flag=0; flag1=0; l=strlen(s); l1=strlen(s1); for(i=0;i<l;i++) { if(s[i]=='.') { flag=1; break; } } //判断第一个数是否为小数点 if(flag) { for(l--;l>0;l--) { if(s[l]=='0') s[l]='\0'; // 从后面开始,将0全部变成结束标志。 else if(s[l]=='.') { s[l]='\0'; break; // 遇到小数点也变成结束标志,然后跳出 } else break; // 遇到数字直接跳出 } } for(i=0;i<l1;i++) { if(s1[i]=='.') { flag1=1; break; } } if(flag1) { for(l1--;l1>0;l1--) { if(s1[l1]=='0') s1[l1]='\0'; else if(s1[l1]=='.') { s1[l1]='\0'; break; } else break; } }// 同上。。 if(strcmp(s,s1)==0) printf("YES\n");// 相等YES ,反之NO。 else printf("NO\n"); } return 0; }
相关文章推荐
- hdu 2054
- HDU 2054 A==B?
- HDU 2054 字符串 比较两个数大小,忽略整数前面的0和小数最后的0
- HDU 2054 A == B?
- hdu 2054 A == B ? (java)
- HDU 2054 A == B ?
- HDU 2053a/b + c/d 2054 又见gcd
- HDU 2054 A==B? 大数
- HDU 2054 A == B ?
- hdu 2054
- HDU 2054
- HDU 2054 大数比较
- hdu 2054 (典型字符串模拟)
- hdu 2054 A == B ? (java)
- HDU 2054 A == B ?
- hdu 2054 A == B ?
- 大数--HDU 2054 A==B?(java)
- HDU 2054
- HDU-2054 A==B?
- hdu 2054 A == B ? (java大数)