比大小
来源:互联网 发布:算法图解 微盘 编辑:程序博客网 时间:2024/04/23 19:13
比大小
时间限制: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>int main(){int i,j;char a[1005],b[1005];int k;while(1){scanf("%s %s",&a,&b);i=strlen(a);j=strlen(b);if(a[0]=='0'&&b[0]=='0')break;if(a[0]=='-'&&b[0]!='-')k=-1;else if(a[0]!='-'&&b[0]=='-')k=1;else if(a[0]!='-'&&b[0]!='-'){if(i>j)k=1;elseif(i<j)k=-1;elseif(i==j){for(i=0;i<j;i++){if(a[i]>b[i]){k=1;break;}if(a[i]<b[i]){k=-1;break;}}if(i>=j)k=0;}}else if(a[0]=='-'&&b[0]=='-'){if(i>j)k=-1;if(i<j)k=1;if(i==j){for(i=1;i<j;i++){if(a[i]>b[i]){k=-1;break;}if(a[i]<b[i]){k=1;break;}}if(i>=j)k=0;}}if(k==-1)printf("a<b\n");if(k==0)printf("a==b\n");if(k==1)printf("a>b\n");}return 0;}
写的太麻烦了,不想改了,就这样吧
0 0
- 比大小
- 比大小
- 比大小
- 比大小
- 比大小
- 比大小
- 比大小
- 比大小
- 比大小
- 比大小
- 比大小
- 比大小
- 比大小
- 比大小
- 比大小
- 比大小
- 比大小
- 比大小
- WinPcap学习(九)发送数据包
- Linux环境进程间通信(三) 消息队列(转)
- Linux mysql安装
- Linux环境进程间通信(四) 信号灯(转)
- 常用正则表达式收集
- 比大小
- Foundation框架(下)
- Linux eclipse安装hadoop插件
- NSString 格式符
- Linux环境进程间通信(五): 共享内存(上)(转)
- 互联网真的互联吗?
- (一)栈的模版类实现
- ios之UITabBarItem显示真实自定义的图片而非颜色填充
- VisualStudio系列环境 报错及解决办法