趋势科技笔试第二题 简单点说就是深度优先搜索

public class Combination {
    public static int getCombinations(int[] numbers, int target) {
        List<List<Integer>> total = new ArrayList<>();
        List<Integer> list = new ArrayList<>();
        if (numbers == null || numbers.length <= 0)
            return -2;
        calculate(total,target,list,numbers);

        if (total == null)
            return -1;
        int length = 0;
        for (List<Integer> result:total)
            length += result.size();
        return length;
    }

    public static void calculate(List<List<Integer>> total, int target,List<Integer> list,int[] numbers){
        if (target == 0){
            ArrayList<Integer> resultList = new ArrayList<>(list);
            if (IsValid(resultList,numbers))
                if (contains(total,resultList) == false)
                    total.add(resultList);
            return;
        }

        int[] a = {1,5,10,20,50,100};

        for (int i=0;i<a.length&&a[i]<=target;i++){
            target -= a[i];
            list.add(a[i]);
            calculate(total,target,list,numbers);
            target += list.get(list.size()-1);
            list.remove(list.size()-1);

        }
    }

    public static boolean IsValid(List<Integer> list, int[] numbers){
        Map<Integer,Integer> map = new HashMap<>();
        int[] a = {1,5,10,20,50,100};
        for (int i=0;i<a.length;i++)
            map.put(a[i],0);

        for (int k:list){
            map.put(k,map.get(k)+1);
        }

        List<Integer> values = new ArrayList<>(map.values());
        for (int i=0;i<numbers.length;i++) {
            if (values.get(i) > numbers[i])
                return false;

        }
        return true;
    }

    public static boolean contains(List<List<Integer>> total, List<Integer> list){
        Collections.sort(list);
        if (total.contains(list))
            return true;
        return false;
    }

    public static void main(String[] args) {
        int numbers[] = {6,5,4,3,2,1};
        int length = Combination.getCombinations(numbers,11);
        System.out.println(length);

    }
}

#趋势科技##笔试题目#
全部评论
楼主ac了?我测试了下感觉结果有点问题啊
1 回复 分享
发布于 2019-08-11 18:26

相关推荐

hso_:哈哈哈哈哈哈我没offer一样在同一道题开喷了
投递深圳同为数码等公司10个岗位
点赞 评论 收藏
分享
找不到工作死了算了:没事的,雨英,hr肯主动告知结果已经超越大部分hr了
点赞 评论 收藏
分享
评论
1
6
分享
牛客网
牛客企业服务