我是靠谱客的博主 俏皮身影,最近开发中收集的这篇文章主要介绍2087. 网格图中机器人回家的最小代价,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

走直线就对了,不需要拐弯抹角

class Solution {
    public int minCost(int[] startPos, int[] homePos, int[] rowCosts, int[] colCosts) {
         int x = startPos[0] - homePos[0];
        int y = startPos[1] - homePos[1];
        
        int ans = 0;

        // 计算机器人横向走的代价
        if (x < 0){
            // 计算到家的距离,直接走直线
            for (int i = startPos[0] + 1; i <= homePos[0]; i++){
                ans += rowCosts[i];
            }
        } else {
            for (int i = startPos[0] - 1; i >= homePos[0]; i--){
                ans += rowCosts[i];
            }
        }
        
        // 计算机器人纵向走的代价
        if (y < 0){
            for (int i = startPos[1] + 1; i <= homePos[1]; i++){
                ans += colCosts[i];
            }
        } else {
            for (int i = startPos[1] - 1; i >= homePos[1]; i--){
                ans += colCosts[i];
            }
        }
        return ans;
    }
}

最后

以上就是俏皮身影为你收集整理的2087. 网格图中机器人回家的最小代价的全部内容,希望文章能够帮你解决2087. 网格图中机器人回家的最小代价所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(40)

评论列表共有 0 条评论

立即
投稿
返回
顶部