n个数里面找出几个数,加起来之和最大 ,且总和要是k的倍数

该代码实现了一个功能,从给定的整数数组中找出若干个数,使得它们的和是k的倍数,并确保这个和是所有可能组合中最大的。首先,对数组进行排序,然后通过递归方式获取所有可能的子集,计算每个子集的和。如果子集和为k的倍数且大于当前最大和,则更新最大和与结果子集。同时,检查所有剩余数的和是否也为k的倍数,若满足条件则更新结果。最后返回满足条件的最大子集。
摘要由CSDN通过智能技术生成

题目描述: 让你从n个数里面找出几个数,加起来之和最大 。且总和要是k的倍数
在这里插入图片描述
代码如下:

  public static List<Integer> test(int n, int k) {
        int[] nums = new int[n];
        int index = 0;
        Scanner scanner = new Scanner(System.in);
        while (n > 0) {
            String s = scanner.nextLine();
            nums[index] = Integer.parseInt(s);
            index++;
            n--;
        }
        Arrays.sort(nums);//排好序
        List<Integer> numList = new ArrayList<>();
        for (int i : nums) {
            numList.add(i);
        }
        int allSum = getSumByList(numList);
        List<Integer> result = new ArrayList<>();
        int maxSum = 0;
        for (int i = 1; i <= nums.length/2; i++) {
            List<List<Integer>> subList = getSubList(nums, i);
            for (List<Integer> list : subList) {
                int sum = getSumByList(list);
                if (sum % k == 0) {
                    if (sum > maxSum) {
                        result = list;
                        maxSum = sum;
                    }
                }
                if ((allSum - sum) % 5 == 0) {
                    if (allSum - sum > maxSum) {
                        ArrayList<Integer> arrayList = new ArrayList<>(numList);
                        arrayList.removeAll(list);
                        result = arrayList;
                        maxSum=allSum - sum;
                    }
                }
            }
        }
        return result;
    }

    public static int getSumByList(List<Integer> list) {
        int sum = 0;
        Iterator<Integer> iterator = list.iterator();
        while (iterator.hasNext()) {
            Integer next = iterator.next();
            sum += next;
        }
        return sum;
    }

//从一个数组里面选n个数出来。把所有可能的n个数的情况都查出来
    public static List<List<Integer>> getSubList(int[] nums, int n) {

        List<List<Integer>> result = new ArrayList<>();
        //处理边界情况
        if (n == 1) {
            for (int num : nums) {
                List<Integer> list = new ArrayList<>();
                list.add(num);
                result.add(list);
            }
            return result;
        }
        int[] restNums = Arrays.copyOfRange(nums, 1, nums.length);
        //如果包含当前nums的第一个元素
        List<List<Integer>> subList = getSubList(restNums, n - 1);
        for (List<Integer> list : subList) {
            List<Integer> list1 = new ArrayList<>();
            list1.addAll(list);
            list1.add(0, nums[0]);
            result.add(list1);
        }

        //如果不包含当前nums的第一个元素
        if(restNums.length>=n){
            List<List<Integer>> subList1 = getSubList(restNums, n);
            result.addAll(subList1);
        }
        return result;
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java全栈研发大联盟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值