华为研发工程师编程题
004汽水瓶
某商店规定:三个空汽水瓶可以换一瓶汽水,允许向老板借空汽水瓶(但是必须要归还)。
小张手上有n个空汽水瓶,她想知道自己最多可以喝到多少瓶汽水。
输入描述:
输入文件最多包含 10 组测试数据,每个数据占一行,仅包含一个正整数 n( 1<=n<=100 ),表示小张手上的空汽水瓶数。n=0 表示输入结束,你的程序不应当处理这一行。
输出描述:
对于每组测试数据,输出一行,表示最多可以喝的汽水瓶数。如果一瓶也喝不到,输出0。
题目讲解
注意:如果手里还剩两个空瓶,可以找老板借一个空瓶,然后再喝一瓶。
关键解题思路
遇到减法要想到除法喝求模。
假设手里还有num>=3个空瓶,每一次喝老板交换后,自己手里还剩下num/3+num%3个空瓶,且喝到了num/3瓶汽水。一直交换下去,直到num<3。最后再处理num<3的情况。
Solution
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner cin = new Scanner(System.in);
ArrayList<Integer> arr = new ArrayList<>();
while(cin.hasNext()){
int a = cin.nextInt();
if(a==0){
break;
}
else{
arr.add(a);
}
}
// System.out.println(arr);
for (int i =0; i<arr.size(); i++){
int num = arr.get(i);
int count = 0;
while(num>=3){
count = count +num/3;
num = num/3 +num%3;
}
if(num==2){
count = count+1;
}
System.out.println(count);
}
}
}
005明明的随机数
明明生成了N个1到500之间的随机整数。请你删去其中重复的数字,即相同的数字只保留一个,把其余相同的数去掉,然后再把这些数从小到大排序,按照排好的顺序输出。
输入描述:
第一行先输入随机整数的个数 N 。
接下来的 N 行每行输入一个整数,代表明明生成的随机数。
具体格式可以参考下面的"示例"。
输出描述:
输出多行,表示输入数据处理后的结果。
关键解题思路
读取的数据放到集合中,然后对集合先排序。再重新初始化一个集合,向新集合中添加不存在的数据。
Solution
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner cin = new Scanner(System.in);
int n = cin.nextInt();
ArrayList<Integer> arr = new ArrayList<>();
for(int i =0; i<n; i++){
arr.add( cin.nextInt());
}
Collections.sort(arr);
// System.out.println(arr);
ArrayList<Integer> newarr = new ArrayList<>();
for(int i =0; i<n ; i++){
if(!newarr.contains(arr.get(i))){
newarr.add(arr.get(i));
}
}
for(int i =0; i< newarr.size(); i++){
System.out.println(newarr.get(i));
}
}
}
006进制转换
写出一个程序,接受一个十六进制的数,输出该数值的十进制表示。
输入描述:
输入一个十六进制的数值字符串。
输出描述:
输出该数值的十进制字符串。不同组的测试用例用\n隔开。
题目描述
十六进制转十进制:0xAA = 10pow(16,0) +10pow(16,1)
关键解题思路
遇到大写字母,需要 -55; 遇到小写字母需要 -78。
Solution
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
int number =0;
Scanner cin = new Scanner(System.in);
String base_16 = cin.nextLine();
int n = base_16.length();
int base_10 = 0;
for(int i =n-1; i>=2; i--){
char cha = base_16.charAt(i);
// System.out.println(cha);
if(cha>='A' && cha<'a'){
number= cha - 55;
}
else if(base_16.charAt(i)>='a' ){
number= cha - 87;
}
else{
number= cha - '0';
}
// System.out.println(number);
base_10 =base_10 + number * (int)((Math.pow(16,n-i-1)));
// System.out.println(base_10);
}
System.out.println(base_10);
}
}
比我想象中简单,继续加油!
用时70min