题解 | #牛群喂食#

牛群喂食

https://www.nowcoder.com/practice/591c222d73914c1ba031a660db2ef73f?tpId=354&tqId=10594712&ru=/exam/oj&qru=/ta/interview-202-top/question-ranking&sourceUrl=%2Fexam%2Foj%3Fpage%3D1%26tab%3D%25E7%25AE%2597%25E6%25B3%2595%25E7%25AF%2587%26topicId%3D354

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param candidates int整型一维数组
     * @param target int整型
     * @return int整型二维数组
     */
    public int[][] cowCombinationSum (int[] candidates, int target) {
        // write code here
        List<List<Integer>> result = new ArrayList<>();
        Arrays.sort(candidates); // Sort the candidates in ascending order
        backtrack(result, new ArrayList<>(), candidates, target, 0);

        int[][] array = new int[result.size()][];
        for (int i = 0; i < result.size(); i++) {
            List<Integer> sublist = result.get(i);
            array[i] = new int[sublist.size()];
            for (int j = 0; j < sublist.size(); j++) {
                array[i][j] = sublist.get(j);
            }
        
        }
         return array;
   }

        private void backtrack(List<List<Integer>> result, List<Integer> current,
                               int[] candidates, int target, int start) {
            if (target < 0) {
                return; // If target becomes negative, stop exploration
            }
            if (target == 0) {
                result.add(new ArrayList<>(current)); // Found a valid combination
                return;
            }

            for (int i = start; i < candidates.length; i++) {
                current.add(candidates[i]);
                // Note that we allow reusing the same candidate to generate combinations
                backtrack(result, current, candidates, target - candidates[i], i);
                current.remove(current.size() - 1);
            }
        }
 }

知识点:

递归

回溯

解题思路:

使用回溯算法来生成所有可能的食物组合,使其总量和为目标数 target。我们首先对 candidates 数组进行了升序排序,然后在 backtrack 方法中,我们尝试将每个 candidate 添加到当前组合中,递归地继续生成下一个食物组合。每次递归时,我们更新目标数为 target - candidates[i],以维护正确的剩余食物需求。

全部评论

相关推荐

mama3925:灵神是天才,路线不适合正常人
点赞 评论 收藏
分享
个人背景:学院二本计科专业&nbsp;大二开始实习个人经历:安克创新&nbsp;、理想汽车、字节跳动碎碎念:我做事只有三分钟热度。看到进了大厂的同学,我会羡慕,也会跟着努力上进;但遇到好看的小说,我又会放下手头的事沉迷其中,之前的坚持也就中断了。我有些自卑,总觉得自己学历和外貌都不够好。之前偶然在网上受到关注,我就喜欢上了上网,因为这里有很多人认可我。但我也很在意别人的评价,偶尔看到嘲讽的言论,会触发我的自卑情绪,让我感到愤怒。有时候我会强硬地回怼,有时候又会懦弱地选择无视。我也有虚荣心。不管是拿到安克、理想还是字节的机会,我在分享的时候都会带着这份心思。我会特意强调自己学历不好,是为了衬托出过程的艰难,以此显得自己更厉害。我知道,人往往会炫耀自己缺少的东西,来掩盖内心的空洞。我总想着走捷径,不太喜欢踏踏实实地做事。找实习的时候,我花了更多时间在研究面试技巧上,而不是提升专业能力。我会反复听面试录音分析技巧,看面试教程学习怎么和不同的面试官沟通,还会每天自言自语练习语言表达,同学都觉得我有点奇怪。我的实习生涯里,侥幸和运气占了很大一部分。我总在想,如果有一天我失去了这份幸运,这些特质可能会让我一蹶不振。ps:&nbsp;很多人会问我学习路线和经验&nbsp;但是就像我上面说的&nbsp;我的实习过程靠的很多是关键节点的运气&nbsp;技术上面我可能不如很多人&nbsp;&nbsp;所以请大家理性求助和理性参考我的回答&nbsp;附上我的投递记录
我的offer在哪里...:从去年看到现在,飞升哥就是榜样
我的求职进度条
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务