#2054
不给定限制范围,你可以意想到n种可能性(坑点所在)
本题主要校验点,小数点后0的处理,不考虑两个数前面无效0和无效符号的处理
增加检验数据
55.0000和55
987.98和987.98000
87和87.01
测试结果
YES
YES
NO
主要用到字符串处理函数
strstr()用于检验目标字符串中第一次出现某个字符或者某段字符的位置
strcmp()用于字符串的比较,若字符串相等,则返回0
同时字符串数组题目没有声明大小,尽量开到最大,这里开到10000,可以AC
题目直达
http://acm.hdu.edu.cn/showproblem.php?pid=2054
AC代码
#include <iostream>
#include <cmath>
#include <cstring>
#include <string>
using namespace std;
//去除小数点后面的0,如果后面全部为0,则去除小数点
void cut(char a[]) {
int len=strlen(a);
//strstr:函数重现,用于检索小数点在a中首次出现的位置。
if(strstr(a,".")) {
for(int i=len-1; a[i]=='0'; i--) {
a[i]='\0';
len--;
}
}
//如果最后只剩下小数点,则将小数点也去除
if(a[len-1]=='.') {
a[len-1]='\0';
}
}
int main() {
char a[100000],b[100000];
while(cin>>a>>b) {
//对字符数组进行处理
cut(a);
cut(b);
//比较两个字符串是否一致
if(!strcmp(a,b)) {
cout<<"YES"<<endl;
} else {
cout<<"NO"<<endl;
}
}
return 0;
}