力扣每日一题--2088. 统计农场中肥沃金字塔的数目

这篇具有很好参考价值的文章主要介绍了力扣每日一题--2088. 统计农场中肥沃金字塔的数目。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

力扣每日一题--2088. 统计农场中肥沃金字塔的数目,leetcode,算法,职场和发展

看到这道题有些人很容易放弃,其实这道题不是很难,主要是题目长,读的容易让人放弃,但是

只要抓住一些性质就可以解决该问题。

    本题中的定义放到图像里其实就是个金字塔,下层的那部分比上一层的那部分,长度加2,

并且该层那个长度区间内都是1才行。是个金字塔形状里都是1就行。

 我们暴力的解法是什么呢?,其实就是遍历整个数组,以每个数组下标为金子塔尖,往下去统计有多少个金字塔,那么这个的时间复杂度是1e8,会超时,所以我们得想别的方法去优化统计多少个金字塔这部分方面去想。那么我们再深入思考一下,我们每次遍历的时候,每次都要向下去统计金字塔,那在统计的时候,我们每次都要关注当前外层是否从上一层外层下来,统计好之后我们怎么想呢?目前已经知道我们的行数是确定的,那么其实只要他的下面的外层可以延伸到金字塔尖的话,我们就可以根据行数和外层可以延伸的长度那么我们就可以知道金字塔数量了,

求每个塔尖的话都是可以这样的,那么外层可以延伸的长度和行数我们怎么确定呢?以正金字塔为例子,一是预处理出来,但是这样复杂度还是比较高,那么我们是不是可以想一下从下往上遍历的话,我们是不是就可以固定金字塔的高度了,比如当前点是i,j,那可以从i + 2到i + 1,i + 1到i。那么高度我们已经确定好了,怎么去确定可以延伸的长度呢?

这个确实不好想,我们目前推出来的只知道每一次长度相差为2,只知道判断从左下角上来,

从右下角上来,但是不知道他中间那段能不能上来,现在就是要确定中间那段如何让他上来,

但是我们仔细想想的话,根据前面的推导,我们在向上推的话,我们是不是只能推导到金字塔尖,那么如果不是金子塔尖呢?我们该怎么去推导呢?其实到这里我们就已经知道了,这是一个动态规划问题,那么动态规划问题的本质是什么呢?找子问题,那么我们是不是可以想一下,最顶上的金子塔尖,是不是可以从下层的金字塔尖推上去,是可以的,我们只用知道左下角,下方,右下角上来就知道了,去个min就可以了,那么状态转移方程就是

f[i][j] = min(f[i + 1][j],min(f[i + 1][j + 1],f[i + 1][j - 1])) + 1;文章来源地址https://www.toymoban.com/news/detail-799847.html

class Solution {
public:
    int f[1100][1100];
    int countPyramids(vector<vector<int>>& grid) 
    {
        memset(f,0,sizeof(f));
        int n = grid.size(),m = grid[0].size();
        //i + 1,j
        //i + 1,j - 1
        //i + 1,j + 1
        int ans = 0;
        for(int i = n - 1;i >= 0;i--)
        {
           for(int j = 0;j < m;j++)
           {
              if(grid[i][j] == 0) continue;
              if(j - 1 < 0 || j + 1 >= m || i + 1 >= n) continue;
              if(grid[i + 1][j] == 0 || grid[i + 1][j - 1] == 0 || grid[i + 1][j + 1] == 0) continue;
              f[i][j] = min(f[i + 1][j],min(f[i + 1][j + 1],f[i + 1][j - 1])) + 1;
              ans += f[i][j];
           }
        }

        //i - 1,j
        //i - 1,j - 1
        //i - 1,j + 1
        memset(f,0,sizeof(f));
        for(int i = 0;i < n;i++)
        {
           for(int j = 0;j < m;j++)
           {
              if(grid[i][j] == 0) continue;
              if(i - 1 < 0 || j + 1 >= m || j - 1 < 0) continue;
              if(grid[i - 1][j] == 0 || grid[i - 1][j - 1] == 0 || grid[i - 1][j + 1] == 0) continue;
              f[i][j] = min(f[i - 1][j],min(f[i - 1][j + 1],f[i - 1][j - 1])) + 1;
              ans += f[i][j];
           }
        }
        return ans;
    }
};

到了这里,关于力扣每日一题--2088. 统计农场中肥沃金字塔的数目的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • opencv基础45-图像金字塔01-高斯金字塔cv2.pyrDown()

    图像金字塔(Image Pyramid)是一种用于多尺度图像处理和分析的技术,它通过构建一系列不同分辨率的图像,从而使得图像可以在不同尺度下进行处理和分析。图像金字塔在计算机视觉、图像处理和计算机图形学等领域中广泛应用,可以用于目标检测、特征提取、图像匹配、尺

    2024年02月13日
    浏览(51)
  • 【力扣每日一题】力扣2765最长交替子数组

    力扣2765最长交替子数组 给你一个下标从 0 开始的整数数组 nums 。如果 nums 中长度为 m 的子数组 s 满足以下条件,我们称它是一个 交替子数组 : m  大于  1  。  s1  =  s0  +  1  。 下标从  0  开始的子数组  s  与数组 [ s0 ,  s1 ,  s0 ,  s1 ,..., s(m-1) % 2 ] 一样。也就是说,

    2024年01月24日
    浏览(52)
  • 力扣每日一题90:子集

    给你一个整数数组  nums  ,其中可能包含重复元素,请你返回该数组所有可能的子集(幂集)。 解集  不能  包含重复的子集。返回的解集中,子集可以按  任意顺序  排列。 示例 1: 示例 2: 提示: 1 = nums.length = 10 -10 = nums[i] = 10 通过次数 330.7K 提交次数 520.9K 通过率 63

    2024年02月06日
    浏览(30)
  • 2023-08-09力扣每日一题

    链接: 1281. 整数的各位积和之差 题意: 十进制每一位的积减去每一位的和 解: 十进制位处理 实际代码: 限制: 1 = n = 10^5

    2024年02月13日
    浏览(45)
  • 2023-09-07力扣每日一题

    链接: [2594. 修车的最少时间](https://leetcode.cn/problems/form-smallest-number-from-two-digit-arrays/) 题意: 一个能力R的人R*N*N分钟修N辆车,求最快多久修完(多人多车) 解: 二分很好想,主要是怎么检查(数学废物润去看题解了) 实际代码: 限制: 1 = ranks.length = 105 1 = ranks[i] = 100 1 = ca

    2024年02月09日
    浏览(39)
  • 2023-08-15力扣每日一题

    链接: 833. 字符串中的查找与替换 题意: n组操作,其中第i组: 检查 子字符串 sources[i] 是否出现在 原字符串 s 的索引 indices[i] 处。 如果没有出现, 什么也不做 。 如果出现,则用 targets[i] 替换 该子字符串。 所有替换操作必须 同时 发生,这意味着替换操作不应该影响彼此

    2024年02月12日
    浏览(40)
  • 2023-07-15力扣每日一题

    链接: 18. 四数之和 题意: 一个数组n,一个目标值t,在数组内找四个数字和等于t,求能有多少种组合 解: 0716:一看怎么昨天卡没打,原来昨天做的第一题不是每日一题,麻了 n很小,200,那么 先排序 ,然后弄一个 双指针开双循环 l,r ,确定每个组合的最大数字-数字4和最

    2024年02月16日
    浏览(40)
  • 2023-08-18力扣每日一题

    链接: 1388. 3n 块披萨 题意: 一个长度3n的环,选n次数字,每次选完以后相邻的数字会消失,求选取结果最大值 解: 这波是~~(ctrl)CV工程师了~~ 核心思想是选取 n个不相邻 的元素一定 合法 ,我推不出来,猜一猜倒是可以O.o DP[i][j] 表示从 [0,i] 中选取 j 个数字的最大值 初始

    2024年02月12日
    浏览(73)
  • 2023-07-29力扣每日一题

    链接: 141. 环形链表 题意: 求链表是否有环 解: 刚好昨天做完的初级算法链表题,翻转和暴力 实际代码: 限制: 链表中节点的数目范围是 [0, 104] -105 = Node.val = 105 pos 为 -1 或者链表中的一个 有效索引 。

    2024年02月15日
    浏览(38)
  • 2023-08-29力扣每日一题

    链接: 823. 带因子的二叉树 题意: 用给的数字建二叉树,要求父节点是子节点的乘积 解: 乐了 1500ms+30MB //注释版120ms+18MB 实际代码: 限制: 1 = arr.length = 1000 2 = arr[i] = 109 arr 中的所有值 互不相同

    2024年02月11日
    浏览(28)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包