创邻科技面试题答案

题目一:

小明的女朋友最喜欢在网上买买买了,可是钱包里钞票有限,不能想买啥就买啥。面对琳琅满目的物品,她想买尽可能多的种类,每种只买一件,同时总价格还不能超过预算上限。于是她请小明写程序帮她找出应该买哪些物品,并算出这些物品的总价格。

输入规范:
每个输入包含两行。第一行是预算上限。第二行是用空格分隔的一组数字,代表每种物品的价格。所有数字都为正整数并且不会超过10000。

输出规范:
对每个输入,输出应买物品的总价格。

输入示例1:
100
50 50
输出示例1:
100

输入示例2:
188
50 42 9 15 105 63 14 30
输出示例2:
160

最先想到dp,后来发现这是求买最多的,于是排下顺序就行了

代码:

package 创邻;

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

/**
 * @author zty200329
 * @date 2020/6/20 15:32
 * @describe:
 */
public class One {
    public static void main(String[] args) {
        int sum = 0;
        Scanner sc = new Scanner(System.in);
        int plan = sc.nextInt();
        sc.nextLine();
        String s = sc.nextLine();
        String[] stringPrice = s.split(" ");
        int len = stringPrice.length;
        int[] buy = new int[len];
        for(int i = 0;i<len;i++){
            buy[i] = Integer.parseInt(stringPrice[i]);
        }
        Arrays.sort(buy);
        for(int i = 0;i<len;i++){
            sum += buy[i];
            if(sum>plan){
                sum -= buy[i];
                break;
            }
        }
        System.out.println(sum);
    }
}

题目二:

李雷和韩梅梅坐前后排,上课想说话怕被老师发现,所以改为传小纸条。为了不被老师发现他们纸条上说的是啥,他们约定了如下方法传递信息:
将26个英文字母(全为大写),外加空格,一共27个字符分成3组,每组9个。也就是ABCDEFGHI是第一组,JKLMNOPQR是第二组,STUVWXYZ是第三组(此处用代表空格)。
然后根据传递纸条那天的日期,改变字母的位置。
先根据月份数m,以整个分组为单位进行循环左移,移动(m-1)次。
然后根据日期数d,对每个分组内的字符进行循环左移,移动(d-1)次。
以3月8日为例,首先移动分组,3月需要循环左移2次,变成:
STUVWXYZ*,ABCDEFGHI,JKLMNOPQR
然后每组内的字符,8日的话需要循环左移7次,最终的编码为:
Z*STUVWXY,HIABCDEFG,QRJKLMNOP
对于要传递信息中的每个字符,用组号和组内序号两个数字来表示。
如果在3月8日传递信息“HAPPY”,那么H位于第2组的第1个,A位于第2组第3个,P位于第3组第9个,Y位于第1组第9个,所以纸条上会写成:
21 23 39 39 19
现在给定日期和需要传递的信息,请输出应该写在纸条上的编码。

输入规范:
每个输入包含两行。第一行是用空格分隔的两个数字,第一个数字是月份,第二个数字是日子。输入保证是一个合法的日期。
第二行为需要编码的信息字符串,仅由A~Z和空格组成,长度不超过1024个字符。

输出规范:
对每个输入,打印对应的编码,数字之间用空格分隔,每个输出占一行。

输入示例1:
1 1
HI
输出示例1:
18 19

输入示例2:
3 8
HAPPY
输出示例2:
21 23 39 39 19

输入示例3:
2 14
I LOVE YOU
输出示例3:
35 25 18 12 29 31 25 23 12 28

代码:

package 创邻;

import java.util.Scanner;

/**
 * @author zty200329
 * @date 2020/6/20 15:55
 * @describe:
 */
public class Two {
    public static void main(String[] args) {
        String s1 = "ABCDEFGHI";
        String s2 = "JKLMNOPQR";
        String s3 = "STUVWXYZ*";
        char[] temp1 = new char[9];
        char[] temp2 = new char[9];
        char[] temp3 = new char[9];
        Scanner sc = new Scanner(System.in);
        int month = sc.nextInt();
        int day = sc.nextInt();
        int modMonth = (month - 1)%3;
        int modDay = (day-1)%9;
        for(int i = 0;i<9;i++){
            temp1[i] = s1.charAt((modDay+i)%9);
            temp2[i] = s2.charAt((modDay+i)%9);
            temp3[i] = s3.charAt((modDay+i)%9);
        }

        char[][] res = {temp1,temp2,temp3};
        char[] tmp = new char[9];
        for(int i =0 ;i<3;i++){
            tmp = res[i];
            res[i]=res[(i+modMonth)%3];
            res[(i+modMonth)%3] = tmp;
        }
        sc.nextLine();
        char[] word = sc.nextLine().toCharArray();
        for(int i = 0 ;i<word.length;i++){
            for(int m = 0;m<res.length;m++){
                for(int n = 0;n<res[0].length;n++){
                    if(word[i]==' '){
                        word[i] = '*';
                    }
                    if(word[i]==res[m][n]){
                        if(i != word.length-1) {
                            System.out.print((m + 1) + "" + (n + 1)+" ");
                        }else{
                            System.out.print((m + 1) + "" + (n + 1));
                        }
                    }
                }
            }
        }
    }
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值