草庐IT

力扣双周赛107

全部标签

力扣精选算法100道——矩阵区域和 (前缀和专题)

目录🎈了解题意 🎈算法原理🎈实现代码🎈了解题意 给定一个大小为mxn的矩阵mat和一个整数k,你需要计算一个新的矩阵answer,其中每个answer[i][j]表示矩阵mat中以坐标(i,j)为中心、边长为2*k+1的正方形区域内所有元素的和。换句话说,对于每个答案元素ret[i][j],其值是由以mat[i][j]为中心、边长为2*k+1的正方形区域内的所有元素之和组成的。以每个元素为中心的大小为(2k+1)*(2k+1)的子矩阵的元素之和。mat是一个二维矩阵(三行三列) k=1的意思是每个下标对应的值向外都扩展1个单位,将扩展1个单位后包含的所有数字都加起来,就是最终的结果(还是该下标

【LeetCode力扣】面试题 17.14. 最小K个数(top-k问题)

目录1、题目介绍2、解题思路2.1、优先队列解法2.2、top-k问题解法1、题目介绍原题链接:面试题17.14.最小K个数-力扣(LeetCode) 题目要求非常简短,也非常简单,就是求一组数中的k个最小数。2、解题思路        如果在正常刷题过程中遇到这种题,那么这道题毋庸置疑是秒杀题,使用最简单的冒泡排序亦或者是直接使用Java中Arrays类的方法sort直接排序后,再取出前k个值。        但是,这是一道面试题,面试题的精髓就是要尽可能的压缩时间复杂度和空间复杂度,以达到给面试官眼前一亮的效果。显然直接使用自带的排序很难给面试官眼前一亮的效果,而该题有一种统称叫:top-

牛客周赛 Round 32 F.小红的矩阵修改【三进制状态压缩dp】

原题链接:https://ac.nowcoder.com/acm/contest/75174/F时间限制:C/C++1秒,其他语言2秒空间限制:C/C++262144K,其他语言524288K64bitIOFormat:%lld题目描述小红拿到了一个字符矩阵,矩阵中仅包含"red"这三种字符。小红每次操作可以将任意字符修改为"red"这三种字符中的一种。她希望最终任意两个相邻的字母都不相同。小红想知道,至少需要修改多少个字符?输入描述:第一行输入两个正整数n,m,代表矩阵的行数和列数。接下来的n行,每行输入一个长度为m的、仅由"red"这三种字符组成的字符串。1≤n≤41≤m≤1000输出描述

1.19 力扣中等图论

200.岛屿数量给你一个由 '1'(陆地)和 '0'(水)组成的的二维网格,请你计算网格中岛屿的数量。岛屿总是被水包围,并且每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成。此外,你可以假设该网格的四条边均被水包围。示例1:输入:grid=[["1","1","1","1","0"],["1","1","0","1","0"],["1","1","0","0","0"],["0","0","0","0","0"]]输出:1示例2:输入:grid=[["1","1","0","0","0"],["1","1","0","0","0"],["0","0","1","0","0"],["0"

leetcode第 381 场周赛最后一题 差分,对称的处理

第381场周赛-力扣(LeetCode)最后一题3017.按距离统计房屋对数目II-力扣(LeetCode)dijkstra超时了,看了灵神的解题方法力扣(LeetCode)官网-全球极客挚爱的技术成长平台,其实是差分优化的暴力统计灵神说的“撤销操作”,就是先不加那条xy新路,统计出所有距离对数,然后再加上那条路做修改。做修改需要推一下变短的位置。灵神封装写的特别好,这道题不封装一下,有问题改起来很麻烦。目录统计原始距离对数:找规律:灵神暴力左右:差分:做修改:第一种:第二种:关于小于区间右端点(x+y)/2:(等于过不了)当x==y及x==y+1时没有缩短任何距离。不需要操作参考代码:统计原

Offer必备算法_前缀和_牛客+力扣OJ题详解(由易到难)

目录前缀和算法介绍一维前缀和二维前缀和①牛客DP34【模板】前缀和解析代码 ②牛客DP35 【模板】二维前缀和解析代码③力扣724.寻找数组的中心下标解析代码④力扣238.除自身以外数组的乘积解析代码⑤力扣560.和为K的子数组解析代码⑥力扣974.和可被K整除的子数组解析代码⑦力扣525.连续数组解析代码⑧力扣1314.矩阵区域和解析代码本篇完。前缀和算法介绍        前缀和算法是一种用于高效计算数组前缀和的算法。前缀和是指从数组的起始位置到某一位置的所有元素的和。前缀和算法其实是一个小的动态规划,其算法一般步骤如下:一维前缀和创建一个与原始数组相同长度的前缀和数组。初始时,前缀和数组

力扣215.数组中第K大元素(堆排序、快排序)[javaScript]

力扣215.数组中第K大元素(堆排序、快排序)[javaScript]给定整数数组nums和整数k,请返回数组中第k个最大的元素。请注意,你需要找的是数组排序后的第k个最大的元素,而不是第k个不同的元素。你必须设计并实现时间复杂度为O(n)的算法解决此问题。示例1:输入:[3,2,1,5,6,4],k=2输出:5示例2:输入:[3,2,3,1,2,4,5,5,6],k=4输出:4首先这题需要第k大的元素,即将数组排序后,index+1下标的元素则是,第index+1大的元素。需要时间复杂度为O(n)的算法。如果用常规的内置函数的排序很难达到这样的时间复杂度,所以我们考虑到使用堆排序和快排序这两

力扣LCR 165. 解密数字(动态规划)

Problem:LCR165.解密数字文章目录题目描述:思路解题方法复杂度Code题目描述:思路1.每个阶段从1个或者2个数字翻译2.intdpn+1dp[i]表示长度位i的数字序列有多少种翻译方法,到达i这个状态,那上一步只有可能是选择了1个或者两个数字翻译,也就是从状态i-1,i-2转换过来,dp[i]的值也有dp[i-1]和dp[i-2]推到过来;3.dp[i]=dp[i-1]+dp[i-2];(前提是2个数字不超过25)解题方法1.将给定的数字ciphertext存入数组中;2.编写判断当前两个数字位是否在解密的范围内(函数名为isValid(inta,intb))3.初始化dp[0]

力扣报错runtime error: load of null pointer of type ‘int‘解决思路

记录本算法小白刷力扣的这道题遇到的报错349.两个数组的交集https://leetcode.cn/problems/intersection-of-two-arrays/出现报错的代码 /***Note:Thereturnedarraymustbemalloced,assumecallercallsfree().*/int*intersection(int*nums1,intnums1Size,int*nums2,intnums2Size,int*returnSize){inthash[1000]={0};intresult[1000];//交集是去重的,最多只有1000个数for(inti

力扣刷题之旅:进阶篇(六)—— 图论与最短路径问题

         力扣(LeetCode)是一个在线编程平台,主要用于帮助程序员提升算法和数据结构方面的能力。以下是一些力扣上的入门题目,以及它们的解题代码。  --点击进入刷题地址 引言         在算法的广阔天地中,图论是一个非常重要的领域。图论问题常常涉及到节点之间的连接关系和路径问题,而最短路径问题则是其中的经典之一。今天,我们就来一起探索一道关于图论与最短路径的经典题目:“单源最短路径问题”。题目描述:        给定一个带权有向图,图中包含n个节点和m条边,每条边都有一个权值表示通过这条边所需的花费。现在,我们需要找出从给定起点到其他所有节点的最短路径。示例:输入:图的邻