Java 题解 | #牛群的喂养顺序II#

牛群的喂养顺序II

https://www.nowcoder.com/practice/05abc133293a42358bbbb4016034728e

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param numCows int整型
     * @param feedOrders int整型二维数组
     * @return int整型一维数组
     */
    public int[] findFeedOrderII (int numCows, int[][] feedOrders) {
        // write code here
        int[] feed = new int[numCows];
        int visited = 0;
        List<Integer> res = new ArrayList<>();
        Queue<Integer> queue = new LinkedList<>();
        List<List<Integer>> lists = new ArrayList<>();

        for (int i = 0; i < numCows; i++) {
            lists.add(new ArrayList<>());
        }

        for (int[] feeds : feedOrders) {
            feed[feeds[0]]++;
            lists.get(feeds[1]).add(feeds[0]);
        }

        for (int i = 0; i < numCows; i++) {
            if (feed[i] == 0) {
                queue.offer(i);
                visited++;
                res.add(i);
            }
        }

        while (!queue.isEmpty()) {
            int index = queue.poll();
            List<Integer> list = lists.get(index);
            for (int i : list) {
                feed[i]--;
                if (feed[i] == 0) {
                    queue.offer(i);
                    res.add(i);
                    visited++;
                }
            }
        }

        if (visited == numCows) {
            int[] result = new int[res.size()];
            for (int i = 0; i < res.size(); i++) {
                result[i] = res.get(i);
            }
            return result;
        } else {
            return new int[0];
        }
    }
}

该代码使用的编程语言是Java。

该题表达的知识点:

  1. 数组:使用int[]表示整数数组。
  2. 列表:使用ListArrayList来动态管理列表。
  3. 队列:使用QueueLinkedList来实现队列数据结构。
  4. 二维数组和二维列表:使用int[][]List<List<Integer>>表示二维整数数组和二维列表。
  5. 循环:使用for循环遍历数组和列表。
  6. 添加元素:使用list.add(element)将元素添加到列表中。
  7. 检查队列是否为空:使用queue.isEmpty()判断队列是否为空。
  8. 入队和出队操作:使用queue.offer(element)向队列中添加元素,使用queue.poll()从队列中取出并删除第一个元素。
  9. 转换数组和列表:使用.toArray()方法将列表转换为数组。

代码的文字解释大纲如下:

  1. 定义一个函数findFeedOrderII,参数为牛的数量numCows和喂养订单的二维数组feedOrders
  2. 创建一个整数数组feed,用于记录每头牛的喂养次数,默认都为0。
  3. 创建一个整数变量visited,用于记录已访问的牛的数量。
  4. 创建一个列表res,用于记录按照喂养顺序的牛的索引。
  5. 创建一个队列queue,用于存放待访问的牛的索引。
  6. 创建一个二维列表lists,用于记录每个饲料的制造者所喂养的牛的索引。
  7. 遍历feedOrders数组,统计每头牛的喂养次数,并将对应的牛的索引添加到lists列表中。
  8. 遍历feed数组,找出初始时没有被喂养过的牛,将其索引加入队列、visited自增并添加到res列表中。
  9. 使用while循环,当队列不为空时进行以下操作:出队一个牛的索引index,并获取对应的饲料制造者列表list。遍历list中的每个制造者的索引i,更新对应牛的喂养次数feed[i]--。如果更新后的喂养次数为0,将该牛的索引入队、visited自增并添加到res列表中。
  10. 判断是否所有牛都被喂养过,如果是,则将res列表转换为数组返回;否则,返回空数组。
全部评论

相关推荐

bg双非本科,方向是嵌入式。这次秋招一共拿到了&nbsp;8&nbsp;个&nbsp;offer,最高年包&nbsp;40w,中间也有一段在海康的实习经历,还有几次国家级竞赛。写这篇不是想证明什么,只是想把自己走过的这条路,尽量讲清楚一点,给同样背景的人一个参考。一、我一开始也很迷茫刚决定走嵌入式的时候,其实并没有一个特别清晰的规划。网上的信息很零散,有人说一定要懂底层,有人说项目更重要,也有人建议直接转方向。很多时候都是在怀疑:1.自己这种背景到底有没有机会2.现在学的东西到底有没有用3.是不是已经开始晚了这些问题,我当时一个都没答案。二、现在回头看,我主要做对了这几件事第一,方向尽早确定,但不把自己锁死。我比较早就确定了嵌入式这个大方向,但具体做哪一块,是在项目、竞赛和实习中慢慢调整的,而不是一开始就给自己下结论。第二,用项目和竞赛去“证明能力”,而不是堆技术名词。我不会刻意追求学得多全面,而是确保自己参与的每个项目,都能讲清楚:我负责了什么、遇到了什么问题、最后是怎么解决的。第三,尽早接触真实的工程环境。在海康实习的那段时间,对我触动挺大的。我开始意识到,企业更看重的是代码结构、逻辑清晰度,以及你能不能把事情说清楚,而不只是会不会某个知识点。第四,把秋招当成一个需要长期迭代的过程。简历不是一次写完的,面试表现也不是一次就到位的。我会在每次面试后复盘哪些问题没答好,再针对性补。三、我踩过的一些坑现在看也挺典型的:1.一开始在底层细节上纠结太久,投入产出比不高2.做过项目,但前期不会总结,导致面试表达吃亏3.早期有点害怕面试,准备不充分就去投这些弯路走过之后,才慢慢找到节奏。四、给和我背景相似的人一点建议如果你也是双非,准备走嵌入式,我觉得有几件事挺重要的:1.不用等“准备得差不多了”再投2.项目一定要能讲清楚,而不是做完就算3.不要只盯着技术,多关注表达和逻辑很多时候,差的不是能力,而是呈现方式。五、写在最后这篇总结不是标准答案,只是我个人的一次复盘。后面我会陆续把自己在嵌入式学习、竞赛、实习和秋招中的一些真实经验拆开来讲,希望能对后来的人有点帮助。如果你正好也在这条路上,希望你能少走一点弯路。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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