题解 | #大胃王牛牛# java

大胃王牛牛

https://www.nowcoder.com/practice/4e55777e218b4850928d054a8cddaf50

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param grass int整型一维数组
     * @param cost int整型一维数组
     * @return int整型
     */
    public int can_complete_circuit (int[] grass, int[] cost) {
        // write code here
        int n = grass.length;

        for (int start = 0; start < n; start++) {
            int totalGrass = 0;
            int totalCost = 0;
            boolean canComplete = true;

            for (int i = 0; i < n; i++) {
                int index = (start + i) % n;
                totalGrass += grass[index];
                totalCost += cost[index];

                if (totalCost > totalGrass) {
                    canComplete = false;
                    break;
                }
            }

            if (canComplete) {
                return start + 1; // 返回下标,从1开始计数
            }
        }

        return -1;
    }
}

Java 编程语言。

该题考察了以下知识点:

  1. 循环遍历
  2. 索引计算

代码的文字解释如下:

  • 获取牛棚的数量 n。
  • 使用外层循环遍历每个牛棚作为起点,将起点索引标记为 start
  • 在内层循环中,模拟从起点出发走完环形路线的过程,使用 index 记录当前所在牛棚的索引。
  • 计算总草料 totalGrass 和总消耗 totalCost 分别累加草料和消耗。
  • 如果在某个牛棚处总消耗超过总草料,说明无法走完环形路线,将 canComplete 标记为 false 并中断循环。
  • 如果 canComplete 仍然为 true,表示可以走完环形路线,返回当前起点索引加1(从1开始计数)。
  • 如果所有起点都无法完成,返回 -1 表示无解。
全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务