比大小

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

比如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

代码:

import java.math.*; import java.util.*; public class Main{ public static void main(String[]args){ Scanner in=new Scanner(System.in); while(in.hasNext()) { BigInteger x=in.nextBigInteger(); BigInteger y=in.nextBigInteger();//一下是三种比较方法 if(x.compareTo(BigInteger.ZERO)==0&&y.compareTo(BigInteger.ZERO)==0) break; //if(x.equals( BigInteger.ZERO)&&y.equals( BigInteger.ZERO)) break;//把BigInteger转化为int // if(x.intValue()==0&&y.intValue()==0) break; else{ int n=x.compareTo(y); if(n>0) System.out.println("a>b"); else if(n==0)System.out.println("a==b"); else System.out.println("a<b"); } } } }c语言代码:

#include<stdio.h> #include<string.h> int main() { int i; while(1) { char a[1001],b[1001]; int m=0,n=0; scanf("%s%s",a,b); if(a[0]=='0'&&b[0]=='0') break; n=strlen(a);m=strlen(b); if((n>m)&&(a[0]!='-'&&b[0]!='-')||(n<m)&&(a[0]=='-'&&b[0]=='-')) printf("a>b\n"); if((n<m)&&(a[0]!='-'&&b[0]!='-')||(n>m)&&(a[0]=='-'&&b[0]=='-')) printf("a<b\n"); if(n==m) { for(i=0;i<=n;i++) { if(a[i]==b[i]) {if(strcmp(a,b)==0) {printf("a==b\n");break; }} if((a[i]>b[i])&&(a[0]!='-'&&b[0]!='-')||(a[i]<b[i])&&(a[0]=='-'&&b[0]=='-')) {printf("a>b\n");break;} if((a[i]<b[i])&&(a[0]!='-'&&b[0]!='-')||(a[i]>b[i])&&(a[0]=='-'&&b[0]=='-')) { printf("a<b\n");break;} } } if(a[0]=='-'&&b[0]!='-') printf("a<b\n"); if(a[0]=!'-'&&b[0]=='-') printf("a>b\n"); } return 0; }

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值