蓝桥杯简单题
第一题
问题描述
给定一个长度为n的数列,将这个数列按从小到大的顺序排列。1<=n<=200
输入格式
第一行为一个整数n。
第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000。
输出格式
输出一行,按从小到大的顺序输出排序后的数列。
样例输入
5
8 3 6 4 9
样例输出
3 4 6 8 9
import java.util.*;
public class Main{
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int[] arr = new int[n];
for (int i = 0;i < n;i++){
arr[i] = sc.nextInt();
}
for(int i = 0;i < n-1;i++){
for(int j = 0;j< n-1-i;j++){
if(arr[j] > arr[j+1]){
int temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
for(int i = 0;i<n;i++){
System.out.print(arr[i]+" ");
}
}
}
第二题
问题描述
给定n个十六进制正整数,输出它们对应的八进制数。
输入格式
输入的第一行为一个正整数n (1<=n<=10)。
接下来n行,每行一个由09、大写字母AF组成的字符串,表示要转换的十六进制正整数,每个十六进制数长度不超过100000。
输出格式
输出n行,每行为输入对应的八进制正整数。
【注意】
输入的十六进制数不会有前导0,比如012A。
输出的八进制数也不能有前导0。
样例输入
2
39
123ABC
样例输出
71
4435274
【提示】
先将十六进制数转换成某进制数,再由某进制数转换成八进制。
import java.math.BigInteger;
import java.util.*;
import java.lang.*;
public class Main{
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
String arr[] = new String[n];
for(int i = 0;i < n;i++){
arr[i] = sc.next();
}
for(int i = 0;i < n;i++){
/*int temp = Integer.parseInt(arr[i],16);
arr[i] = Integer.toOctalString(temp);
System.out.println(arr[i]);*///大于Integer.MAX_VALUE小于Integer.MIN_VALUE
BigInteger temp = new BigInteger(arr[i],16);
arr[i] = temp.toString(8);
System.out.println(arr[i]);
}
}
}
第三题
问题描述
从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。
注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。
样例输入
FFFF
样例输出
65535
import java.lang.*;
import java.util.*;
import java.math.BigInteger;
public class Main{
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
String s = sc.next();
BigInteger temp = new BigInteger(s,16);
s = temp.toString(10);
System.out.println(s);
}
}