杭电2054 A==B?

杭电2054

http://acm.hdu.edu.cn/showproblem.php?pid=2054

杭电2054 A==B?

 

题目非常简洁,就是判断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;
}

比较坑。