java 十六进制31 1_如何优化Java程序:十进制转十六进制(2的31次方以内的正整数)...

代码如下:

package com.java;

import java.util.Scanner;

public class TestTransform {

public static void main(String[] args) {

Scanner sc = new Scanner(System.in);

for ( ; ; ){

System.out.println(“请输入小于2的31次方的正整数:(輸入-1結束程序)”);

int i = sc.nextInt();

if(i==0){

System.out.println(“程序结束!”);

break;

}else if(i < Math.pow(2, 4) && i > 0){

int a = i & 15;

String s = a<=9 ? a+”” : (char)(a-10+’a’)+””;

System.out.println(s);

}else if(i < Math.pow(2, 8) && i >= Math.pow(2, 4)){

int a = i & 15;

String s = a<=9 ? a+”” : (char)(a-10+’a’)+””;

int i1 = i>>4;

int a1 = i1 & 15;

String s1 = a1<=9 ? a1+”” : (char)(a1-10+’a’)+””;

System.out.println(s1+s);

}else if(i < Math.pow(2, 12) && i >= Math.pow(2, 8)){

int a = i & 15;

String s = a<=9 ? a+”” : (char)(a-10+’a’)+””;

int i1 = i>>4;

int a1 = i1 & 15;

String s1 = a1<=9 ? a1+”” : (char)(a1-10+’a’)+””;

int i2 = i1>>4;

int a2 = i2 & 15;

String s2 = a2<=9 ? a2+”” : (char)(a2-10+’a’)+””;

System.out.println(s2+s1+s);

}else if(i < Math.pow(2, 16) && i >= Math.pow(2, 12)){

int a = i & 15;

String s = a<=9 ? a+”” : (char)(a-10+’a’)+””;

int i1 = i>>4;

int a1 = i1 & 15;

String s1 = a1<=9 ? a1+”” : (char)(a1-10+’a’)+””;

int i2 = i1>>4;

int a2 = i2 & 15;

String s2 = a2<=9 ? a2+”” : (char)(a2-10+’a’)+””;

int i3 = i2>>4;

int a3 = i3 & 15;

String s3 = a3<=9 ? a3+”” : (char)(a3-10+’a’)+””;

System.out.println(s3+s2+s1+s);

}else if(i < Math.pow(2, 20) && i >= Math.pow(2, 16)){

int a = i & 15;

String s = a<=9 ? a+”” : (char)(a-10+’a’)+””;

int i1 = i>>4;

int a1 = i1 & 15;

String s1 = a1<=9 ? a1+”” : (char)(a1-10+’a’)+””;

int i2 = i1>>4;

int a2 = i2 & 15;

String s2 = a2<=9 ? a2+”” : (char)(a2-10+’a’)+””;

int i3 = i2>>4;

int a3 = i3 & 15;

String s3 = a3<=9 ? a3+”” : (char)(a3-10+’a’)+””;

int i4 = i3>>4;

int a4 = i4 & 15;

String s4 = a4<=9 ? a4+”” : (char)(a4-10+’a’)+””;

System.out.println(s4+s3+s2+s1+s);

}else if(i < Math.pow(2, 24) && i >= Math.pow(2, 20)){

int a = i & 15;

String s = a<=9 ? a+”” : (char)(a-10+’a’)+””;

int i1 = i>>4;

int a1 = i1 & 15;

String s1 = a1<=9 ? a1+”” : (char)(a1-10+’a’)+””;

int i2 = i1>>4;

int a2 = i2 & 15;

String s2 = a2<=9 ? a2+”” : (char)(a2-10+’a’)+””;

int i3 = i2>>4;

int a3 = i3 & 15;

String s3 = a3<=9 ? a3+”” : (char)(a3-10+’a’)+””;

int i4 = i3>>4;

int a4 = i4 & 15;

String s4 = a4<=9 ? a4+”” : (char)(a4-10+’a’)+””;

int i5 = i4>>4;

int a5 = i5 & 15;

String s5 = a5<=9 ? a5+”” : (char)(a5-10+’a’)+””;

System.out.println(s5+s4+s3+s2+s1+s);

}else if(i < Math.pow(2, 28) && i >= Math.pow(2, 24)){

int a = i & 15;

String s = a<=9 ? a+”” : (char)(a-10+’a’)+””;

int i1 = i>>4;

int a1 = i1 & 15;

String s1 = a1<=9 ? a1+”” : (char)(a1-10+’a’)+””;

int i2 = i1>>4;

int a2 = i2 & 15;

String s2 = a2<=9 ? a2+”” : (char)(a2-10+’a’)+””;

int i3 = i2>>4;

int a3 = i3 & 15;

String s3 = a3<=9 ? a3+”” : (char)(a3-10+’a’)+””;

int i4 = i3>>4;

int a4 = i4 & 15;

String s4 = a4<=9 ? a4+”” : (char)(a4-10+’a’)+””;

int i5 = i4>>4;

int a5 = i5 & 15;

String s5 = a5<=9 ? a5+”” : (char)(a5-10+’a’)+””;

int i6 = i5>>4;

int a6 = i6 & 15;

String s6 = a6<=9 ? a6+”” : (char)(a6-10+’a’)+””;

System.out.println(s6+s5+s4+s3+s2+s1+s);

}else if(i < Math.pow(2, 31) && i >= Math.pow(2, 30)){

int a = i & 15;

String s = a<=9 ? a+”” : (char)(a-10+’a’)+””;

int i1 = i>>4;

int a1 = i1 & 15;

String s1 = a1<=9 ? a1+”” : (char)(a1-10+’a’)+””;

int i2 = i1>>4;

int a2 = i2 & 15;

String s2 = a2<=9 ? a2+”” : (char)(a2-10+’a’)+””;  //2 147 483 647    1 073 741 824

int i3 = i2>>4;

int a3 = i3 & 15;

String s3 = a3<=9 ? a3+”” : (char)(a3-10+’a’)+””;

int i4 = i3>>4;

int a4 = i4 & 15;

String s4 = a4<=9 ? a4+”” : (char)(a4-10+’a’)+””;

int i5 = i4>>4;

int a5 = i5 & 15;

String s5 = a5<=9 ? a5+”” : (char)(a5-10+’a’)+””;

int i6 = i5>>4;

int a6 = i6 & 15;

String s6 = a6<=9 ? a6+”” : (char)(a6-10+’a’)+””;

int i7 = i6>>4;

int a7 = i7 & 15;

String s7 = a7<=9 ? a7+”” : (char)(a7-10+’a’)+””;

System.out.println(s7+s6+s5+s4+s3+s2+s1+s);

}

}

}

}

感觉代码太长而且有重复,一定有优化的空间,请各位技术大佬不吝赐教!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值