杭电2054 A==B?
杭电2054
http://acm.hdu.edu.cn/showproblem.php?pid=2054
题目非常简洁,就是判断A是否与B相等。
但要是直接这么认为就完了,既然是ACM的题目,不玩点花样还叫ACM吗?想想A+B都出了多少变题了。。。
这题主要麻烦在它没给数据范围,很可能大的要命还全是0(前导/后导)。
我们要做的就是拿数组存储。
用strstr(,".')判断小数点是否存在,然后删去后导0(若有)。
最后用strcmp函数判断字符串是否一致即可。
#include <iostream>
#include <cstring>
using namespace std;
char a[100000],b[100000];
void cp(char a[]){
int len;
len=strlen(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(){
while(cin>>a>>b){
cp(a);
cp(b);
if(!strcmp(a,b)){
cout<<"YES"<<endl;
} else {
cout<<"NO"<<endl;
}
}
return 0;
}
比较坑。