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;
        }
    }
};
相关推荐
6Hzlia1 天前
【Hot 100 刷题计划】 LeetCode 739. 每日温度 | C++ 逆序单调栈
c++·算法·leetcode
良木生香1 天前
【C++初阶】:STL——String从入门到应用完全指南(1)
c语言·开发语言·数据结构·c++·算法
XWalnut1 天前
LeetCode刷题 day16
数据结构·算法·leetcode·链表·动态规划
foundbug9991 天前
基于混合整数规划的电池容量优化 - MATLAB实现
数据结构·算法·matlab
memcpy01 天前
LeetCode 2452. 距离字典两次编辑以内的单词【暴力;字典树】中等
算法·leetcode·职场和发展
王老师青少年编程1 天前
csp信奥赛C++高频考点专项训练之贪心算法 --【排序贪心】:魔法
c++·算法·贪心·csp·信奥赛·排序贪心·魔法
wearegogog1231 天前
基于和差波束法的单脉冲测角MATLAB实现
人工智能·算法·matlab
AI科技星1 天前
灵魂商数(SQ) · 全域数学统一定义【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
晓觉儿1 天前
【GPLT】2026年第十一届团队程序设计天梯赛赛后题解(已写2h,存档中)
数据结构·c++·算法·深度优先·图论