HDU 5059 Help him(细节)

系统 1615 0

HDU 5059 Help him

题目链接

直接用字符串去比較就可以,先推断原数字正确不对,然后写一个推断函数,注意细节,然后注意判掉空串情况

代码:

      #include <cstdio>
#include <cstring>

const int N = 105;
char n[N], a[N], b[N];

bool judge(char *str) {
	int len = strlen(str);
	if (len == 0) return false;
	int s = 0;
	if (str[s] == '-') {
		if (len == 1) return false;
		s++;
	}
	if (len != 1 && str[s] == '0') return false;
	for (int i = s; i < len; i++) {
		if (str[i] < '0' || str[i] > '9')
			return false;
	}
	return true;
}

bool big(char *a, char *b) {
	if (a[0] == '-' && b[0] != '-') return false;
	if (a[0] != '-' && b[0] == '-') return true;
	int i = 0, j = 0;
	int lena = strlen(a), lenb = strlen(b);
	bool flag = true;
	if (a[i] == '-' && b[j] == '-') {
		i++; j++;
		flag = false;
	}
	if (lena > lenb) return flag;
	if (lena < lenb) return !flag;
	while (i < lena && j < lenb) {
		if (a[i] > b[j]) return flag;
		else if (a[i] < b[j]) return !flag;
		i++; j++;
	}
	return true;
}

bool solve() {
	if (!judge(n)) return false;
	if (big(n, a) && big(b, n)) return true;
	return false;
}

int main() {
	while (gets(n) != NULL) {
		scanf("%s%s%*c", a, b);
		while (!judge(a) || !judge(b));
		printf("%s\n", solve() ? "YES" : "NO");
	}
	return 0;
}
    


HDU 5059 Help him(细节)


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论