【力扣每日一题】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;
    }
};
相关推荐
小飞猪Jay29 分钟前
C++面试速通宝典——13
jvm·c++·面试
Kalika0-041 分钟前
猴子吃桃-C语言
c语言·开发语言·数据结构·算法
代码雕刻家1 小时前
课设实验-数据结构-单链表-文教文化用品品牌
c语言·开发语言·数据结构
sp_fyf_20241 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-02
人工智能·神经网络·算法·计算机视觉·语言模型·自然语言处理·数据挖掘
rjszcb1 小时前
一文说完c++全部基础知识,IO流(二)
c++
小字节,大梦想2 小时前
【C++】二叉搜索树
数据结构·c++
吾名招财2 小时前
yolov5-7.0模型DNN加载函数及参数详解(重要)
c++·人工智能·yolo·dnn
我是哈哈hh3 小时前
专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结
服务器·数据结构·c++·算法·机器学习·深度优先·剪枝
憧憬成为原神糕手3 小时前
c++_ 多态
开发语言·c++
郭二哈3 小时前
C++——模板进阶、继承
java·服务器·c++