当前位置: 首页 > news >正文

【每日刷题】Day135

【每日刷题】Day135

🥕个人主页:开敲🍉

🔥所属专栏:每日刷题🍍

🌼文章目录🌼

1. LCR 011. 连续数组 - 力扣(LeetCode)

2. 【模板】二维前缀和_牛客题霸_牛客网 (nowcoder.com)

3. 1314. 矩阵区域和 - 力扣(LeetCode)

1. LCR 011. 连续数组 - 力扣(LeetCode)

//思路:前缀和+哈希表

//本题思路与 Day132 中的"和为K的子数组" 完全相似

//区别在于哈希中存储的不再是前缀和,而是每个前缀和对应的下标

//同时,还有个最为核心的思想,我们将数组中所有的 0 看作 -1,这样要找数量相同 0 和 1 的最长连续子数组问题就可以转换为最长和为 0 的连续子数组 

class Solution {

public:

    int findMaxLength(vector<int>& nums)

    {

        int sum = 0,ans = 0;

        vector<int> dp;

        unordered_map<int,int> hash;

        for(int i = 0;i<nums.size();i++)

        {

            if(!nums[i]) sum--;//将数组中的 0 看作 -1

            else sum++;

            dp.push_back(sum);//dp数组存储前缀和

            if(!dp[i]) ans = ans>i+1?ans:i+1;//找前缀和为 0 的连续子数组

            else if(hash.find(sum)!=hash.end()) ans = ans>i-hash[sum]?ans:i-hash[sum];

            else hash[sum] = i;//前缀和不为 0 则判断一下在前面能否找到一个前缀和使它们之前出现和为 0 的连续子数组

        }

        return ans;

    }

};

2. 【模板】二维前缀和_牛客题霸_牛客网 (nowcoder.com)

//思路:二位前缀和模板

#include <iostream>

#include <vector>

using namespace std;

int main()

{

    int n,m,q;

    cin>>n>>m>>q;

    vector<vector<int>> arr(n+1,vector<int>(m+1,0));

    vector<vector<long long>> sum(n+1,vector<long long>(m+1,0));

    for(int i = 1;i<n+1;i++)

    {

        for(int j = 1;j<m+1;j++)

        {

            cin>>arr[i][j];

            sum[i][j] = sum[i][j-1]+sum[i-1][j]+arr[i][j]-sum[i-1][j-1];//创建矩阵,套用二位前缀和公式

        }

    }

    while(q--)

    {

        int x1,y1,x2,y2;

        cin>>x1>>y1>>x2>>y2;

        cout<<sum[x2][y2]-sum[x2][y1-1]-sum[x1-1][y2]+sum[x1-1][y1-1]<<endl;//套用子矩阵和公式

    }

   

    return 0;

}

3. 1314. 矩阵区域和 - 力扣(LeetCode)

//思路:二位前缀和

//本题的思路就是 "【模板】二位前缀和" 的思路。

//题目的意思就是:

//知道了题目意思以后,思路就很容易想了。

//想要知道这个新矩阵的和,我们只需要类比 "【模板】二位前缀和" 中的思路即可,即:确定一个起点以及一个终点,起点和终点所形成的子矩阵直接套用公式即可求出和

class Solution {

public:

    vector<vector<int>> matrixBlockSum(vector<vector<int>>& mat, int k)

    {

        int n = mat.size(),m = mat[0].size();

        vector<vector<int>> ans(n,vector<int>(m,0));

        vector<vector<int>> sum(n+1,vector<int>(m+1,0));

        for(int i = 1;i<n+1;i++)

            for(int j = 1;j<m+1;j++)

                sum[i][j] = sum[i][j-1]+sum[i-1][j]+mat[i-1][j-1]-sum[i-1][j-1];//套用前缀和公式


 

        for(int i = 0;i<n;i++)

        {

            for(int j = 0;j<m;j++)

            {

                int x1 = max(0,i-k)+1,y1 = max(0,j-k)+1,x2 = min(n-1,i+k)+1,y2 = min(m-1,j+k)+1;//因为下标从0开始,因此 x1、y1、x2、y2都要+1与 sum 的起始下标对应

                ans[i][j] = sum[x2][y2]-sum[x2][y1-1]-sum[x1-1][y2]+sum[x1-1][y1-1];//确定起点与终点,这里需要仔细思考起点和终点与K的关系。

            }

        }

        return ans;

    }

};

http://www.lryc.cn/news/456662.html

相关文章:

  • Linux运维01:VMware创建虚拟机
  • 服务器平均响应时间和数据包大小关系大吗?
  • Vue入门-指令学习-v-show和v-if
  • nacos多数据源插件介绍以及使用
  • 国庆档不太热,影视股“凉”了?
  • QtDesign预览的效果与程序运行的结果不一致的解决方法
  • 模运算和快速幂
  • 【机器学习】——神经网络与深度学习:从基础到应用
  • Unity各个操作功能+基本游戏物体创建与编辑+Unity场景概念及文件导入导出
  • QT入门教程攻略 QT入门游戏设计:贪吃蛇实现 QT全攻略心得总结
  • Linux No space left on device分析和解决
  • Qt实现Halcon窗口显示当前图片坐标
  • 构建宠物咖啡馆:SpringBoot框架的实现策略
  • Qt开发环境的搭建
  • docker-compose查看容器日志和实时查看日志
  • MVC、MVP和MVVM之间的区别
  • uni-app 打包成app时 限制web-view大小
  • 智能指针(2)
  • [含文档+PPT+源码等]精品基于Nodejs实现的家教服务小程序的设计与实现
  • electron打包报错-winCodeSign无法下载
  • 给Windows系统设置代理的操作方法
  • 高质量带货短视频素材来源推荐
  • torchvision.transforms.Resize()的用法
  • 简单认识 redis -数据类型命令
  • Python 语言学习——应用1.2 数字图像处理(第二节,变换)
  • 【QT Quick】页面布局:手动定位与坐标系转换
  • uniapp自定义导航,全端兼容
  • [论文阅读] DVQA: Understanding Data Visualizations via Question Answering
  • 【PostgreSQL】实战篇——数据备份和恢复的最佳实践和工具
  • 代码随想录算法训练营第二十九天|93.复原IP地址 78.子集 90.子集II