Java蓝桥杯试题集之基础练习10-13 ---- 十进制转十六进制、十六进制转十进制、十六进制转八进制、数列排序

 目录

十进制转十六进制

解题思路

十六进制转十进制

解题思路

十六进制转八进制

解题思路

数列排序

解题思路

这几道题涉及到java进制转换的函数,一定要记住鸭~


 

十进制转十六进制

解题思路

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner in = new Scanner(System.in);
		int a = in.nextInt();
		System.out.println(Integer.toHexString(a).toUpperCase());
	}

}

 

十六进制转十进制

解题思路

这题要注意描述的是不超过8位的十六进制数,所以不能parseInt,会超限,故使用Long的方法parseLong()

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner in = new Scanner(System.in);
		String a = in.nextLine();
		System.out.println(Long.parseLong(a, 16));
	}

}

 

十六进制转八进制

解题思路

这个题有大坑啊!!!十六进制数的位数是100000,测试数据有这么多啊!!柳婼姐姐的算法提交是不能通过的。下面是我找到的前辈的代码。。这题如果是比赛我可能会放弃。。?

这里循环输入的时候如果使用nextLine()就会将输入n之后的回车读入而产生错误,推荐使用next()。

import java.util.Scanner;  
public class Main {  

    public static void main(String[] args)  
    {  
             Scanner sc=new Scanner(System.in);  
             int n=sc.nextInt();  
             String[] st=new String[n];  
             for(int i=0;i<n;i++)  
             {  
             st[i] =sc.next();  
             }   
             for(int i=0;i<n;i++)  
             {  
                 String str1=LiuZhuanEr(st[i]);     
                 int len_str1=str1.length();  
                 if(len_str1%3==1)str1="00"+str1;   
                 else if(len_str1%3==2)str1="0"+str1;  
                 ErZhuanBa(str1);  
                 System.out.println();  
             }  


    }  
public static String LiuZhuanEr(String  str)  
    {  
             int len_str=str.length();  
             StringBuilder str2=new StringBuilder();  
             for(int i=0;i<len_str;++i)   
             {   
             switch(str.charAt(i))   
             {   
             case '0':str2.append("0000");break;   
             case '1':str2.append("0001");break;   
             case '2':str2.append("0010");break;   
             case '3':str2.append("0011");break;   
             case '4':str2.append("0100");break;   
             case '5':str2.append("0101");break;   
             case '6':str2.append("0110");break;   
             case '7':str2.append("0111");break;   
             case '8':str2.append("1000");break;   
             case '9':str2.append("1001");break;   
             case 'A':str2.append("1010");break;   
             case 'B':str2.append("1011");break;   
             case 'C':str2.append("1100");break;   
             case 'D':str2.append("1101");break;   
             case 'E':str2.append("1110");break;   
             case 'F':str2.append("1111");break;   
             default:break;   
             }   
    } return str2.toString();  
    }  
  public static void ErZhuanBa(String str2)  
  {  
           int len=str2.length();  
           int a;  
           a=(str2.charAt(0)-'0')*4+(str2.charAt(1)-'0')*2+(str2.charAt(2)-'0');  
           if(a!=0)
           System.out.print(a);  
           for(int i=3;i<=len-2;i+=3)   
           {   
           a=(str2.charAt(i)-'0')*4+(str2.charAt(i+1)-'0')*2+(str2.charAt(i+2)-'0');   
           System.out.print(a);  
           }   


  }  
}  

 

数列排序

解题思路

import java.util.Arrays;
import java.util.Scanner;

public class 基础练习_数列排序 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner in = new Scanner(System.in);
		int n = in.nextInt();
		int a[] = new int[n];
		for (int i = 0; i < n; i++) {
			a[i] = in.nextInt();
		}
		Arrays.sort(a);
		for (int i = 0; i < n; i++) {
			System.out.print(a[i] + " ");
		}
	}

}

 

 

希望我的记录能够帮到你~ 喜欢请点赞!?


谢谢你看到这里!写作仓促,有疏漏之处还请评论指正,共同探讨进步!


 

已标记关键词 清除标记
相关推荐
©️2020 CSDN 皮肤主题: 像素格子 设计师:CSDN官方博客 返回首页