Day5力扣打卡

这篇具有很好参考价值的文章主要介绍了Day5力扣打卡。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

打卡记录

Day5力扣打卡,leetcode刷题打卡,leetcode,算法,c++

对角线上不同值的数量差(矩阵对角线遍历 + 前缀和)

链接

思路:由于任意行 i 与 列 j,满足对角线上 i == j + t 的关系,t 的范围为 [1 - n, m - 1],设 s = t + n,可以得到 s的范围为 [1, n + m - 1],对应 m x n 矩阵上所有的 n + m - 1 条对角线,以及 i - s + n == j 的关系,根据 i 的范围 [0, m - 1] 可以推出对角线在 [1, n + m - 1] 范围下的 j 的取值范围,即为 [max(n - s, 0), min(n + m - s - 1, n - 1)]。

class Solution {
public:
    vector<vector<int>> differenceOfDistinctValues(vector<vector<int>>& grid) {
        int m = grid.size(), n = grid[0].size();
        vector<vector<int>> ans(m, vector<int>(n));
        for (int s = 1; s <= m + n - 1; ++s) {
            int min_j = max(n - s , 0), max_j = min(m + n - s - 1, n - 1);
            unordered_set<int> st;
            st.clear();
            for (int j = min_j; j < max_j; j++) {
                int i = s - n + j;
                st.insert(grid[i][j]);
                ans[i + 1][j + 1] = st.size();
            }
            st.clear();
            for (int j = max_j; j > min_j; j--) {
                int i = s - n + j;
                st.insert(grid[i][j]);
                ans[i - 1][j - 1] = abs(ans[i - 1][j - 1] - (int)st.size());
            }
        }
        return ans;
    }
};

盛最多水的容器(双指针)

链接

思路:若向内移动短板 ,水槽的短板 min(h[i],h[j]) 可能变大,因此下个水槽的面积可能增大 。若向内移动长板 ,水槽的短板 min(h[i],h[j]) 不变或变小,因此下个水槽的面积一定变小 。因此从边缘往内遍历,尽可能将短板变大,求得储水最大值即为答案。文章来源地址https://www.toymoban.com/news/detail-722785.html

class Solution {
public:
    int maxArea(vector<int> &height) {
        int ans = 0, left = 0, right = height.size() - 1;
        while (left < right) {
            int area = (right - left) * min(height[left], height[right]);
            ans = max(ans, area);
            height[left] < height[right] ? ++left : --right;
        }
        return ans;
    }
};

到了这里,关于Day5力扣打卡的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

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

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

相关文章

  • 力扣算法刷题Day59|单调栈

    力扣题目:# 503.下一个更大元素II  刷题时长:参考题解后2min 解题方法:单调栈 复杂度分析 时间O(n) 空间O(n) 问题总结 如何解决环的问题 本题收获 循环数组解决方案 思路一:将两个nums数组拼接在一起,使用单调栈计算出每一个元素的下一个最大值,最后再把结果集即res

    2024年02月13日
    浏览(84)
  • 蓝桥杯备赛 | 洛谷做题打卡day5

    题目描述 小 K 喜欢翻看洛谷博客获取知识。每篇文章可能会有若干个(也有可能没有)参考文献的链接指向别的博客文章。小 K 求知欲旺盛,如果他看了某篇文章,那么他一定会去看这篇文章的参考文献(如果他之前已经看过这篇参考文献的话就不用再看它了)。 假设洛谷

    2024年01月17日
    浏览(59)
  • 菜鸟刷题Day5

    ⭐作者:别动我的饭 ⭐专栏:菜鸟刷题 ⭐标语:悟已往之不谏,知来者之可追 描述 给你一个数组 nums 。数组「动态和」的计算公式为:runningSum[i] = sum(nums[0]…nums[i]) 。 请返回 nums 的动态和。 示例: 解题思路 1.通过观察示例可以发现,其实runningSum[0]和nums[0]相等,runningSu

    2023年04月08日
    浏览(34)
  • 算法打卡day32|贪心算法篇06|Leetcode 738.单调递增的数字、968.监控二叉树

    Leetcode 738.单调递增的数字 题目链接:738.单调递增的数字  大佬视频讲解:单调递增的数字视频讲解  个人思路 这个题目就是从例子中找规律,例如 332,从后往前遍历,32不是单调递增将2变为9,3减1,变成了329,遍历到2,32不是递增,将2变为9,3减1,变成299,符合题目条件,打印

    2024年04月16日
    浏览(46)
  • 力扣算法刷题Day39|动态规划:不同路径 I&II

    力扣题目:#62.不同路径 刷题时长:参考题解后10min 解题方法:动规 复杂度分析 时间O(m*n) 空间O(m*n) 问题总结 初始化二维数组的python语法:i 对应 m,j 对应n 二维遍历顺序,从上到下从左到右通过两层for循环实现,其中startindex应为1 本题收获 动规思路 确定dp数组及下标的含义

    2024年02月12日
    浏览(52)
  • 【C++刷题集】-- day5

    目录 选择题 单选 编程题 统计回文⭐ 【题目解析】 【解题思路 - 穷举】 【优化】 连续最大和⭐ 【题目解析】 【解题思路】 【空间优化】 1、 在上下文和头文件均正常情况下,以下程序的输出结果是  ( ) 1 无任何输出 2 陷入死循环 正确答案: 解析: do while循环是先执行

    2024年02月14日
    浏览(39)
  • 【C刷题】day5

    一、选择题 1、如下程序的功能是( ) A: 测字符数组ch的长度 B: 将数字字符串ch转换成十进制数 C: 将字符数组ch中的小写字母转换成大写 D: 将字符数组ch中的大写字母转换成小写 【答案】: D 【解析】: 考点:大小写转换(ASCII值) 一个字母对应的小写比大写的ASCII码值大

    2024年02月08日
    浏览(42)
  • 牛课刷题Day5(编程题)

    1.合并数组 arr1 和数组 arr2。不要直接修改数组 arr,结果返回新的数组 正确答案: 2.在数组 arr 的 index 处添加元素 item。不要直接修改数组 arr,结果返回新的数组 正确答案: 解析:本题可使用splice方法,该方法可接收多个参数。第一个参数表示数组起始位置,第二个参数表

    2024年02月08日
    浏览(31)
  • 【力扣二刷思路】DAY5

    给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。 子数组 是数组中的一个连续部分。 初始化变量 :在开始时,将存储最大子数组和的 ans 初始化为整型的最小值 INT_MIN ,将当前累加的子数组和 total 初始化为 0。

    2024年03月23日
    浏览(36)
  • 力扣算法刷题Day42|动态规划:01背包问题 分割等和子集

    力扣题目:01背包问题(二维数组) 刷题时长:参考题解 解题方法:动态规划 + 二维dp数组 复杂度分析 时间 空间 问题总结 理解递推公式困难 本题收获 动规思路:两层for循环,第一层i遍历物品,第二层j枚举背包容量以内所有值 确定dp数组及下标的含义:dp[i][j] 表示从下标

    2024年02月13日
    浏览(62)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包