HDU 2054 A == B ?

A == B ?

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 96648    Accepted Submission(s): 15372


Problem Description
Give you two numbers A and B, if A is equal to B, you should print "YES", or print "NO".
 

Input
each test case contains two numbers A and B.
 

Output
for each case, if A is equal to B, you should print "YES", or print "NO".
 

Sample Input
  
  
1 2 2 2 3 3 4 3
 

Sample Output
  
  
NO YES YES NO
 

做本题是要判断是否存在前导0存在以及小数点后是否最后几位是0;



#include <stdio.h>
#include <string.h>
#include <iostream>
using namespace std;
char a[1000005],b[1000005];

int Judge(char *a, int &x){
	int len = strlen(a),i = 0,flag = 0;
	
	while(a[i + 1] != '.' && a[i] == '0' && i < len)
		i ++;
	x = i;
	
	for(i = 0; i < len; i ++)
		if(a[i] == '.')
			flag = 1;
	
	i = len - 1;
	while(i >= 0 && a[i] == '0' && flag && a[i] != '.'){
		a[i] = '\0';
		i --;
	}
	if(a[i] == '.')
		a[i] = '\0';	
}

int main(){
	
	while(cin >>a >>b){
		int x,y,flag = 0;

		Judge(a,x);
		Judge(b,y);

		if(strlen(a) - x != strlen(b) - y){
			printf("NO\n");
			continue;
		}
		else{
			while(x < strlen(a)){
				if(a[x] != b[y]){
					flag = 1;
					break;
				}
				x ++;	y ++;
			}
			
			if(flag)
				printf("NO\n");
			else
				printf("YES\n");
		}
	}
	
	return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值