【每日刷题】Day135

news2025/1/9 16:34:45

【每日刷题】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.coloradmin.cn/o/2200207.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于SSM的共享读书网站

文未可获取一份本项目的java源码和数据库参考。 1.1 题目背景 进入新时代&#xff0c;中国的经济建设和社会发展需要与之相适应的人力资源相匹配。如何提升人力资源的素养&#xff0c;是新时代中国持续发展亟待解决的问题[1]。阅读不失为其中一个有效的手段。有效有益的阅读能…

【每日一题 | 24.10.6】确定字符串是否包含唯一字符

1. 题目2. 解题思路3. 代码实现&#xff08;AC_Code&#xff09; 个人主页&#xff1a;C_GUIQU 归属专栏&#xff1a;每日一题 1. 题目 确定字符串是否包含唯一字符 2. 解题思路 题目要求&#xff1a;判断输入的字符串是否唯一&#xff0c;这里想到可以借助布尔数组。 第一…

软件测试外包干了4年,感觉废了....

先说一下自己的情况&#xff0c;大专生&#xff0c;18年通过校招进入湖南某软件公司&#xff0c;干了接近4年的功能测试&#xff0c;今年年初&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了四年的功能测试…

【模板进阶】std::conditional

一、 s t d : : c o n d i t i o n a l std::conditional std::conditional的使用 C 11 C11 C11标准引入了 s t d : : c o n d i t i o n a l std::conditional std::conditional&#xff0c;这是一个类模板&#xff0c;用于表现一种编译期间的分支逻辑。 它的实现代码比较简…

【斯坦福CS144】Lab4

一、实验目的 完成一个网络接口实现。 二、实验内容 完成一个网络接口实现&#xff0c;其大部分工作是&#xff1a;为每个下一跳IP地址查找(和缓存)以太网地址。而这种协议被称为地址解析协议ARP。 三、实验过程 在minnow目录下输入git merge origin/check4-startercode获…

[ C++ ] C++ 类和对象 -- 类的六个默认成员函数

目录 1.构造函数 2.析构函数 3.拷贝构造函数 4.赋值操作符重载 5.两个取地址操作符的重载 在C中当你创建一个空类&#xff0c;那这个空类是什么都没有吗&#xff1f;不是的&#xff0c;编译器会默认帮你生成六个成员函数 1.构造函数 构造函数是特殊的成员函数&#xff0c;…

使用数据库:

数据库&#xff1a; 1.为何需要数据库&#xff1f; 存储数据方法 第一种&#xff1a;用大脑记住数据&#xff0c; 第二种&#xff1a;写纸上&#xff0c; 第三种&#xff1a;写在计算机的内存中&#xff0c; 第四种&#xff1a;写出磁盘文件 2.数据库能做什么&#xff1…

【探索艺术新纪元:Midjourney中文版,让创意无界!】

&#x1f3a8; 艺术&#xff0c;从此触手可及 在这个数字时代&#xff0c;Midjourney中文版正引领一场艺术创作的革命。作为一款前沿的AI绘画工具&#xff0c;它利用深度学习技术&#xff0c;将你的想象转化为触手可及的艺术作品。无需深厚的绘画功底&#xff0c;只需简单的文…

机器学习:opencv--图像拼接

目录 前言 一、两个函数 1.显示图像 2.计算图片特征与描述符 二、代码实例 1.准备图像 2.特征检测 3.特征匹配 4.图像变换 5.图像融合 前言 图像拼接是一种将多张图像合成一幅大图的技术&#xff0c;常用于全景图生成、图像拼接和图像合成等应用场景。 一、两个函数…

第二十三天|回溯算法| 39. 组合总和,40. 组合总和II,131. 分割回文串

目录 39. 组合总和 未剪枝 剪枝优化 40. 组合总和II 131. 分割回文串 回溯 回溯动态规划优化回文串判断 今天的题目自己都没啥思路&#xff0c;二刷的时候再理解一下。尤其是131. 39. 组合总和 本题和77.组合 &#xff0c;216.组合总和III的区别是&#xff1a;本题没有…

IDEA 输入英文字体变了的问题

**问题&#xff1a;**有时不知道按了什么快捷键导致在 IDEA 输入英文字体变了&#xff0c;如下所示&#xff0c;看起来特别不顺眼&#xff1a; 出现以上问题是因为在输入时切换了中文输入法&#xff0c;并且在提示文字时按了 Shift 空格 键&#xff0c;导致出现以上字体变化情…

H、Happy Number(2024牛客国庆集训派对day7)

题目链接&#xff1a; H-Happy Number_2024牛客国庆集训派对day7 (nowcoder.com) 题目描述&#xff1a; 翻译为中文&#xff1a; 数据范围&#xff1a; 输入样例&#xff1a; 680 输出样例&#xff1a; 326623 分析: 本来以为是dfs&#xff0c;但是看到数据范围1e9, 联想到是…

uniapp自定义导航,全端兼容

我们在用uniapp 开发应用的时候&#xff0c;有的页面需要自定义导航&#xff0c; 1.如果普通的直接使用uni 扩展柜组件的 uni-nav-bar 也基本够用&#xff0c; 2.如果稍微带点自定义的这个值无法支持的&#xff0c;特别在小程序端&#xff0c;胶囊是会压住右边的按钮的 自定…

多模态简单了解

多模态 1.文本编码2. ViT图像编码器2.1图像矩阵self-attention计算&#xff1a; 3.Transformer多模态3.1CLIP 图文交互3.2 对比学习训练3.3 flamingo 图文交互3.4 LLava 图文交互 1.文本编码 简介&#xff1a; 即通过embedding将字符向量化&#xff0c;进入模型即可。 2. ViT…

水下图像增强(论文复现)

本文所涉及所有资源均在 传知代码平台 可获取。 目录 概述 一、论文思路 二、模型介绍&#xff1a; 三、实现方法 四、复现过程(重要) 部署方式 概述 2021年11月&#xff0c;提出一种用于水下图像增强的U型Transformer模型&#xff0c;这是首次在水下图像增强任务中使用Transfo…

InnoDB 磁盘结构 - RedoLog

文章目录 RedoLog是什么刷盘机制崩溃恢复相关参数Redo Log 和 Undo Log 对比 https://dev.mysql.com/doc/refman/8.0/en/innodb-redo-log.html RedoLog是什么 RedoLog 是MySQL的一种日志文件&#xff0c;用于在崩溃恢复期间纠正由不完整事务写入的数据。在正常操作过程中&…

AtCoder Beginner Contest 374

C - Separated Lunch 题目&#xff1a; 思路&#xff1a; dfs枚举每个数是否选入a数组中&#xff0c;求和比较 代码&#xff1a; #include <bits/stdc.h>using namespace std;typedef long long LL;const int N25;int a[N]; bool st[N]; int mn0x3f3f3f3f; int sum; …

VMWare安装ubuntu22虚拟机

1.下载VMware虚拟机和ubuntu 下载地址&#xff1a; VMware Workstation Pro - Download (softonic.com) Download Ubuntu Desktop | Ubuntu 2.Ubuntu的安装 1.VMware创建虚拟机。 2.选择默认即可点击下一步。 3.找到刚才下载的ubuntu20.04。选择下面的稍后安装操作系统。 …

众智OA办公系统 Account/Login SQL注入漏洞复现

0x01 产品简介 众智OA办公系统是一种专门为企业和机构的日常办公工作提供服务的综合性软件平台。它凭借先进的技术和人性化的设计理念,实现了信息的快速传递和自动化处理,帮助企业和机构实现信息化、自动化、智能化和标准化的办公管理。 0x02 漏洞概述 众智OA办公系统 Acc…

【命令操作】linux上watch命令详解 _ 统信 _ 麒麟 _ 方德

原文链接&#xff1a;【命令操作】linux上basename和dirname使用详解 | 统信 | 麒麟 | 方德 Hello&#xff0c;大家好啊&#xff01;今天给大家带来一篇关于Linux上watch命令的详解文章。watch命令是Linux系统中非常有用的一个工具&#xff0c;它可以定期执行指定的命令并在终端…