2078. 两栋颜色不同且距离最远的房子 力扣

题目描述:

街上有 n 栋房子整齐地排成一列,每栋房子都粉刷上了漂亮的颜色。给你一个下标从 0 开始且长度为 n 的整数数组 colors ,其中 colors[i] 表示第 i 栋房子的颜色。

返回 两栋 颜色 不同 房子之间的 最大 距离。

i 栋房子和第 j 栋房子之间的距离是 abs(i - j) ,其中 abs(x)x 的绝对值。

题目链接:2078. 两栋颜色不同且距离最远的房子 - 力扣(LeetCode)

解题思路:

对于一种颜色来说,其他的颜色都是不同的。

比如 ***1*** , 8, 3, 8, ***3***

对于 '1' 这个颜色,就是 ***1*** , 0, 0, 0, 0,最大距离为4

对于'8' 这个颜色,就是 ***0*** , 8, 0, 0, 0,最大距离为3

对于'3' 这个颜色,就是 ***0*** , 0, 3, 0, ***3***,最大距离为4

所以只需要遍历O(n),查找从头开始与第一个元素不同的最远距离 比较 从尾开始与最后一个元素不同的最远距离,哪个更大即是答案。

代码如下:

cpp 复制代码
class Solution {
public:
    int maxDistance(vector<int>& colors) {
        int length = colors.size();
        int ans1 = 0;
        int ans2 = 0;
        for ( int i = 1; i < length; ++ i ){
            if ( colors[ 0 ] != colors[ i ] ){
                ans1 = i;
            }
        }
        -- length;
        for ( int i = length - 1; i >= 0; -- i ){
            if ( colors[ length ] != colors[ i ] ){
                ans2 = i;
            }
        }

        if ( ans1 ){
            return ans1 > length - ans2 ? ans1 : length - ans2;
        }else{
            return 0;
        }
    }
};
相关推荐
洛水水10 分钟前
【力扣100题】81.寻找两个正序数组的中位数
数据结构·算法·leetcode
happymaker062639 分钟前
LeetCodeHot100——155.最小栈
算法
洛水水1 小时前
【力扣100题】85.每日温度
算法·leetcode·职场和发展
Coder-magician1 小时前
《代码随想录》刷题打卡day15:二叉树part05
数据结构·c++·算法
Kurisu_红莉栖1 小时前
力扣56合并区间
算法·leetcode
Irissgwe1 小时前
算法的时间复杂度和空间复杂度
数据结构·c++·算法·c·时间复杂度·空间复杂度
随意起个昵称1 小时前
区间dp-基础题目3(永别)
c++·算法
周末也要写八哥1 小时前
有向图Hierholzer算法的另一种实现
算法
bIo7lyA8v1 小时前
算法调优中的性能回归与基准测试分析的技术8
算法·数据挖掘·回归
有点。1 小时前
C++贪心算法二(练习题)
c++·算法·贪心算法