NYOJ 比大小

来源:互联网 发布:qq游戏网络加速器 编辑:程序博客网 时间:2024/04/29 04:53

 原题网页链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=73

比大小

时间限制:3000 ms  |  内存限制:65535 KB
难度:2
描述

给你两个很大的数,你能不能判断出他们两个数的大小呢?

比如123456789123456789要大于-123456

输入
每组测试数据占一行,输入两个不超过1000位的10进制整数a,b
数据保证输入的a,b没有前缀的0。
如果输入0 0表示输入结束。测试数据组数不超过10组
输出
如果a>b则输出“a>b”,如果a<b则输出“a<b”,如果相等则输出“a==b”。
样例输入
111111111111111111111111111 88888888888888888888-1111111111111111111111111  222222220 0
样例输出
a>ba<b


简单的大数问题,用了最笨的办法,思路清晰,但是写的比较啰嗦。

代码如下:


#include<stdio.h>#include<string.h>#include<stdlib.h>int main(){int t=0,lena,lenb;char a[1100],b[1100];while(scanf("%s%s",a,b)&&(t<=10)&&(strcmp("0",a)!=0)||(strcmp("0",b)!=0)){lena=strlen(a);lenb=strlen(b);if(a[0]=='-'&&b[0]!='-')  printf("a<b\n");else if(a[0]!='-'&&b[0]=='-')  printf("a>b\n");else if(a[0]=='-'&&b[0]=='-'&&lena!=lenb)//此处一定要将字符串a,b的长度不相等写上 {    if(lena>lenb)       printf("a<b\n");            if(lena<lenb)   printf("a>b\n");}else if(a[0]!='-'&&b[0]!='-'&&lena!=lenb)//同上 {if(lena<lenb)   printf("a<b\n");if(lena>lenb)   printf("a>b\n");}else if(a[0]=='-'&&b[0]=='-'&&lena==lenb){if(strcmp(a,b)>0)   printf("a<b\n");else if(strcmp(a,b)<0)   printf("a>b\n");else    printf("a==b\n");}else if(a[0]!='-'&&b[0]!='-'&&lena==lenb){if(strcmp(a,b)>0)   printf("a>b\n");else if(strcmp(a,b)<0)   printf("a<b\n");else     printf("a==b\n");}t++;    }return 0;}



0 0
原创粉丝点击