【力扣每日一题】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;
    }
};
相关推荐
小白狮ww4 分钟前
RStudio 教程:以抑郁量表测评数据分析为例
人工智能·算法·机器学习
AAA修煤气灶刘哥5 分钟前
接口又被冲崩了?Sentinel 这 4 种限流算法,帮你守住后端『流量安全阀』
后端·算法·spring cloud
tan180°37 分钟前
Boost搜索引擎 查找并去重(3)
linux·c++·后端·搜索引擎
Boop_wu1 小时前
[数据结构] 栈 · Stack
数据结构
kk”1 小时前
C语言快速排序
数据结构·算法·排序算法
阿昭L1 小时前
c++中获取随机数
开发语言·c++
纪元A梦1 小时前
贪心算法应用:基因编辑靶点选择问题详解
算法·贪心算法
3壹1 小时前
数据结构精讲:栈与队列实战指南
c语言·开发语言·数据结构·c++·算法
aaaweiaaaaaa2 小时前
c++基础学习(学习蓝桥杯 ros2有C基础可看)
c++·学习·蓝桥杯·lambda·ros2·智能指针·c++类
skytier2 小时前
Construct内报错和定位解决
算法