【力扣每日一题】2023.9.2 最多可以摧毁的敌人城堡数量

目录

题目:

示例:

分析:

代码:


题目:

示例:

分析:

这道题难在阅读理解,题目看得我匪夷所思,错了好多个测试用例才明白题目说的是什么。

我简单翻译一下就是寻找1和-1之间0最多的数量,1和-1之间只能有0。

我们可以套两层循环,第一层for循环去寻找1,如果找到了1,那么我们开始在当前下标往左右两边寻找最近的-1,并且统计0的数量,需要注意的是如果先碰到了1,那么表示我们无法落脚,也就不能更新答案,因为题目说的我们只能在-1的地方落脚,并且1到-1之间只能有0。

在结束往右寻找的时候,我们可以把往右寻找的下标赋值给第一层循环的下标,因为我们结束往右寻找的时候,下标所在的位置要么是1要么是-1,赋值给第一层循环可以少遍历几次,不过题目中给的数据量比较小,所以这个小优化是可有可无的。

具体操作可以参考下面的代码和动图。

代码:

cpp 复制代码
class Solution {
public:
    int captureForts(vector<int>& forts) {
        int res=0;
        int n=forts.size();
        for(int i=0;i<n;i++){
            if(forts[i]==1){    //遇到了自己的城堡
                int t=0,index=i-1;
                while(index>=0){    //去寻找左边能摧毁的敌人城堡数量
                    if(forts[index]==1) break;  //先遇到自己的城堡则表示左边没有落脚点
                    if(forts[index]==-1){       //当遇到空地就结束寻找并更新答案
                        res=max(res,t);
                        break;
                    }
                    t++;index--;
                }
                t=0,index=i+1;
                while(index<n){     //去寻找右边能摧毁的敌人城堡数量
                    if(forts[index]==1) break;
                    if(forts[index]==-1){
                        res=max(res,t);
                        break;
                    }
                    t++;index++;
                }
                //i=index-1;    //小小优化一下,可有可无
            }
        }
        return res;
    }
};
相关推荐
杨福瑞1 分钟前
数据结构:单链表(2)
c语言·开发语言·数据结构
亮剑20181 小时前
第2节:程序逻辑与控制流——让程序“思考”
开发语言·c++·人工智能
王璐WL1 小时前
【数据结构】单链表及单链表的实现
数据结构
敲代码的瓦龙1 小时前
操作系统?进程!!!
linux·c++·操作系统
TiAmo zhang1 小时前
现代C++的AI革命:C++20/C++23核心特性解析与实战应用
c++·人工智能·c++20
黑屋里的马1 小时前
java的设计模式之桥接模式(Bridge)
java·算法·桥接模式
z187461030031 小时前
list(带头双向循环链表)
数据结构·c++·链表
sin_hielo1 小时前
leetcode 1611
算法·leetcode
李小白杂货铺2 小时前
识别和破除信息茧房
算法·信息茧房·识别信息茧房·破除信息茧房·算法推荐型茧房·观点过滤型茧房·茧房
来荔枝一大筐2 小时前
C++ LeetCode 力扣刷题 541. 反转字符串 II
c++·算法·leetcode