实习+秋招刷题004-006

华为研发工程师编程题

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值