HDU2054 - A == B ? - 模拟

题意:字面意思。

思路:这题,需要往字面意思深入考虑。
需要考虑前导零呀,小数点呀,字符串处理啊啊等。
直接判断A和B是否相等于是就会output limit exceed,且只能比较int范围内的数字大小。

#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;

#define inf 0x3f3f3f3f

char s[100000],a[100000],b[100000];

void vis(char s[100000])
//void vis(char s)//这样不对,传入单个字符
{
    int l=strlen(s);
    int k=0,i,j;
    for(i=0;ij;i--)//把小数点后面无效的零变成字符串结束的标志'\0'
        {
            if(s[i]=='0')
            {
                s[i]='\0';
                l--;
            }
            else
                break;
        }
        if(s[l-1]=='.')//处理完到小数点后面一位的字符后,开始处理小数点
            s[l-1]='\0';//这种处理适用于6.00变为6.的这种情况
    }
    return ;
}

int main()
{
//需要考虑小数点,找到小数点把最后面无效的零去掉再比较
//默认前导0可以不考虑
    while(~scanf("%s %s",a,b))
    {
        vis(a);
        vis(b);//先对字符串a、b进行处理,找到小数点并且去掉后面无效的零
        int t=strcmp(a,b);
        if(t==0)
            printf("YES\n");
        else
            printf("NO\n");
        memset(a,'\0',sizeof(a));
        memset(b,'\0',sizeof(b));
    }
    return 0;
}

你可能感兴趣的:(HDU2054 - A == B ? - 模拟)