南阳 oj 比大小 题目73

来源:互联网 发布:爬山算法 贪心算法 编辑:程序博客网 时间:2024/04/29 03:48

/*
比大小
时间限制: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  22222222
0 0
样例输出a>b
a<b
上传者张云聪*/
#include<stdio.h>#include<string.h>char s1[1010],s2[1010];int main(){  int l1,l2,a,b;  while(scanf("%s %s",s1,s2)!=EOF)  {  l1=strlen(s1);  l2=strlen(s2);  if(s1[0]=='0'&&s2[0]=='0') break;//都为0时   if(s1[0]=='-'&&s2[0]!='-') printf("a<b\n");//一正一负   if(s1[0]!='-'&&s2[0]=='-') printf("a>b\n");if(l1<l2)//长度 { if(s1[0]=='-'&&s2[0]=='-') printf("a>b\n"); if(s1[0]!='0'&&s2[0]!='0') printf("a<b\n");     }   if(l1>l2){ if(s1[0]=='-'&&s2[0]=='-') printf("a<b\n"); if(s1[0]!='-'&&s2[0]!='-') printf("a>b\n");   } if(l1==l2)  {    if(strcmp(s1,s2)==0) printf("a==b\n");      if(strcmp(s1,s2)>0) printf("a<b\n");//切记比较函数大于0时  是  后边的字符串比前边大   if(strcmp(s1,s2)<0) printf("a>b\n");   }  }  return 0;}

0 0
原创粉丝点击