首页 > 其他 > 详细

HDU2054 - A == B ? - 模拟

时间:2020-06-22 23:20:46      阅读:73      评论:0      收藏:0      [点我收藏+]

题意:字面意思。

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

#include<algorithm>
#include<iostream>
#include<string.h>
#include<stdio.h>
#include<math.h>
#include<queue>
#include<stack>
#include<map>
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;i<l;i++)//寻找是否存在小数点
    {
        if(s[i]==‘.‘)
        {
            k=1;
            j=i;//记录小数点的下标
            break;
        }
    }

    if(k==1)//如果存在小数点
    {
        for(i=l-1;i>j;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 ? - 模拟

原文:https://www.cnblogs.com/OFSHK/p/13179662.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!