前缀和第二弹

力扣560.和为k的子数组

子数组经典暴力解法:枚举全部位置,因为取值为可能为负

首先把前缀和,和出现的次数都存储一下,一般前缀和就出现一次,然后往后找,如果前缀和-k就说明有一段数组是等于sum-k

class Solution {
    public int subarraySum(int[] nums, int k) {
        //前缀和  字符串组成sum次数
    Map<Integer,Integer>hash=new HashMap<>();
    hash.put(0,1);
    //ret统计最终结果,sum表示前一个位置的前缀和
    int sum=0;
    int ret=0;
    for(int m:nums){
        //sum+=表示当前位置前缀和
        sum+=m;
        //统计结果
        ret+=hash.getOrDefault(sum-k,0);
        hash.put(sum,hash.getOrDefault(sum,0)+1);

    }
    return ret;
    }
}

力扣974.和可被K整除的子数组

引入同余定理

2.java(负数%正数)的结果以及修正

负%正=负->修正 a%p+p,但是假如a是一个正数,那么正数%p然后再加上一个p就变成了多了个p,所以再次%. 也就是说(a%p+p)%p

我们这里求的是前面的x存储了次数,然后看后面的是否有和他相同的,假如有相同的那么就ret表示次数,先从hash里面找前面有没有相同的,然后把前面相同的值加上

假如说前缀和-这个之前的前缀和也可以整除,那么说明a,b可以整除​​​​​​​

class Solution {
    public int subarraysDivByK(int[] nums, int k) {
     Map<Integer,Integer> hash=new HashMap<>();
     hash.put(0,1);
     int sum=0;
     int ret=0;
     for(int x:nums){
         //sum是前缀和
         sum+=x;
         //r是表示前缀和的余数
         int r=(sum%k+k)%k;
         ret+=hash.getOrDefault(r,0);
         hash.put(r,hash.getOrDefault(r,0)+1);
     }

return ret;
    }
}

力扣525.连续数组

解法:

前缀和+哈希表

1.哈希表里面存什么(因为我们要知道子数组的长度,所以需要用下标来计算长度)

hash<int,int>前缀和,下标

2.什么时候存入哈希表

使用完之后,丢进哈希表

3.如果有重复的<sum,i>怎么办

只保留前面的那一对<sum,i>

4.默认的前缀和为0的情况,如何存储

假如是【0,1】我们改成[-1,1]这时候前缀和是0,我们的长度设置要是-1,他的长度才能是2

hash[0]=-1

5.长度如何计算

 public int findMaxLength(int[] nums) {
        //我们只关心长度,只要下标,才能计算长度
        //一个是前缀和,一个就是下标
        Map<Integer,Integer>hash=new HashMap<>();
        hash.put(0,-1);
        int sum=0;
        int ret=0;
        for(int i=0;i<nums.length;i++){
            if(nums[i]==0){
                sum+=-1;
            }else{
            sum+=1;//计算当前位置前缀和
            }
            //现在前面找一个值也等于sum
            if(hash.containsKey(sum))
            //那么此时的下标,就是我们要找的下标
            ret=Math.max(ret,i-hash.get(sum));
            //看你存不存在当前sum,要是不存在,就放进去即可
            else  hash.put(sum,i);
        }
        return ret;
    }

力扣1314.矩阵区域和

是一个上面加上一个左边,但是上面和左边都包括你的斜上方,所以减去一个斜上方,再去加上当前位置的数值。

我们该如何求出我们想要的那个点的值呢

首先我们先把我们想要的区域找好

下标映射关系:

为了方便处理边界情况 我们二维dp都是从1开始计数,但是我们的mat是从0开始计数

所以我们,需要多加一列dp[m+1][n+1]

当我门dp表想填写[i][j]->mat[i-1][j-1],当我们使用dp表的时候,填写ret,使用x1,x2的时候,应该x+1,y+1的位置,修改方式,我们求矩阵下标x1,x2的时候+1即可。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/402211.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Python 如何给出一个周期性函数接近某个值所有的值

Python 如何给出一个周期性函数接近某个值的值 推荐阅读正文一般化周期性函数拓展推荐阅读 Python 寻找一个一维数组中最接近某个值的元素 Python 如何切分函数 正文 一般化周期性函数 本文一看,可能感觉标题有些拗口,难以理解,请看下图: 图像显然具有一定的周期性,如…

特殊文本文件

特殊文件 普通文件.txt属性文件.propertiesXML文件.xml 为什么要用这些特殊文件 存储多个用户的&#xff1a;用户名、密码 存储多个用户的&#xff1a;用户名、密码、家乡、性别 存储有关系的数据&#xff0c;做完系统的配置文件 做为信息进行传输 这些特殊文件&#xff0c;我…

Android中通过属性动画实现文字轮播效果

前些天发现了一个蛮有意思的人工智能学习网站,8个字形容一下"通俗易懂&#xff0c;风趣幽默"&#xff0c;感觉非常有意思,忍不住分享一下给大家。 &#x1f449;点击跳转到教程 一、创建一个自定义ProvinceView类,具体代码如下 /*** Author: ly* Date: 2024/2/22* D…

Redis的常见面试题

目录 前言 Redis支持哪些数据类型 五种核心类型 Zset为什么用跳表不用红黑树 &#xff1f; Redis常见的应用场景&#xff1f; 如何检测Redis的连通性&#xff1f; 如何设置key的过期时间&#xff1f; Redis为什么是单线程模型&#xff1f; Redis里的IO多路复用是什…

恶意代码识别率提升95%!谷歌开源人工智能网络安全防御工具

近日&#xff0c;谷歌日前宣布发起网络安全人工智能防御计划&#xff0c;旨在利用人工智能技术提升网络安全水平&#xff0c;扭转困扰网络安全行业的“防守困境”。 该计划的核心举措是开源Magika&#xff0c;这是一款用于文件类型识别的AI工具&#xff0c;能够帮助检测恶意软件…

国产嵌入式教学实验箱操作教程:2-13 定时器控制实验

一、实验目的 熟悉定时器的基本结构&#xff0c;学习定时器的功能和控制方法&#xff0c;并实现基于定时器中断方式控制程序。 二、实验原理 定时器 TMS320CC6748有4个定时器/计数器&#xff0c;均可配置为64位计数器、两个独立32位计数器及自动重装32位计数器&#xff0c;…

【FreeRTOS基础入门】事件组与同步点

文章目录 前言一、事件组是什么案例1.1 事件组的概念 二、事件组的操作2.1 事件组与其他实现同步与互斥方法的区别2.2 创建事件组2.3 删除事件组2.4 设置事件2.5 等待事件2.6 示例代码 三、同步点3.1 同步点是什么3.2 设置同步点 总结 前言 FreeRTOS是一个广泛应用于嵌入式系统…

我的第一个浏览器插件网页一键上传的开发历史

前言 一键上传选中的网页内容&#xff0c;实现知识快速收藏。如飞书剪存&#xff0c;有道云剪报&#xff0c;MrDoc速记。早在2008年&#xff0c;我参考了有道云一键上传&#xff0c;实现了一个简单的浏览器插件&#xff0c;能方便保存网页内容到个人网站。这些插件目前都很难兼…

Day32 进程Process

文章目录 1.什么是进程1.1 概念1.2 特点1.3 进程段1.4 进程分类1.5 进程状态1.6 进程状态切换图1.7 调度进程 2.进程函数接口2.1 创建进程 fork()2.2 回收资源函数2.3 结束进程2.4 获取进程号 3.exec函数族&#xff08;了解&#xff09;4.守护进程 Daemon4.1 守护进程的特点4.2…

提升技术栈的秘诀:Spring Cloud学习网站带你飞跃职业瓶颈!

介绍&#xff1a;Spring Cloud是一个基于Spring Boot实现的微服务架构开发工具集。 Spring Cloud利用Spring Boot的开发便利性简化了分布式系统基础设施的开发。例如&#xff0c;服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等都是其内置的功能。它的优势包括…

LangChain支持哔哩哔哩视频总结

是基于LangChain框架下的开发&#xff0c;所以最开始请先 pip install Langchain pip install bilibili-api-python 技术要点&#xff1a; 使用Langchain框架自带的Document loaders 修改BiliBiliLoader的源码&#xff0c;自带的并不支持当前b站的视频加载 源码文件修改&a…

前端架构: 实现脚手架终端UI样式之ANSI escape code, Chalk, Ora介绍

在脚手架当中实现命令行的UI显示 1 &#xff09;概述 在命令行中&#xff0c;如果想实现除传统的常规文本以外的内容比如想对字体进行加粗斜体下划线&#xff0c;包括对它改变颜色改变前景色改变后景色等等需要借助一个叫做 ANSI escape code 这样的一个概念它其实是一个标准&…

文献速递:GAN医学影像合成--基于生成对抗网络的肺部图像分类的多域医学图像翻译生成

文献速递&#xff1a;GAN医学影像合成–基于生成对抗网络的肺部图像分类的多域医学图像翻译生成 01 文献速递介绍 在2019年底&#xff0c;一种称为2019冠状病毒病&#xff08;COVID-19&#xff09;的新型冠状病毒肺炎出现&#xff0c;迅速成为全球性大流行。感染COVID-19可以…

18.贪心算法

排序贪心 区间贪心 删数贪心 统计二进制下有多少1 int Getbit_1(int n){int cnt0;while(n){nn&(n-1);cnt;}return cnt; }暴力加一维前缀和优化 #include <iostream> #include <climits> using namespace std; #define int long long const int N2e510; in…

热门游泳耳机哪个牌子好,吐血整理全网高口碑机型!

近年来&#xff0c;游泳已经成为众多人们喜爱的运动项目之一。而在游泳过程中&#xff0c;许多人希望能够享受到音乐的陪伴&#xff0c;以增加运动的乐趣。然而&#xff0c;由于阻力、防水和水压等问题&#xff0c;传统的耳机并不能满足游泳者的需求。因此&#xff0c;在市面上…

基于JAVA+SpringBoot+Vue的前后端分离的电子商城

✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取项目下载方式&#x1f345; 一、项目背景介绍&#xff1a; 在当今数字化时代&…

bat判断vmware 是否已安装

要通过批处理脚本&#xff08;.bat&#xff09;判断VMware是否已安装&#xff0c;您可以尝试以下方法&#xff1a; 检查VMware的进程 您可以检查VMware相关的进程是否在运行。例如&#xff0c;VMware Workstation的进程名通常是vmware-workstation.exe。 echo off tasklist /…

计网 - 域名解析的工作流程

文章目录 Pre引言1. DNS是什么2. 域名结构3. 域名解析的工作流程4. 常见的DNS记录类型5. DNS安全6. 未来的发展趋势 Pre 计网 - DNS 域名解析系统 引言 在我们日常使用互联网时&#xff0c;经常会输入各种域名来访问网站、发送电子邮件或连接其他网络服务。然而&#xff0c;我…

【命令行工具kubectl】

如何在k8s的任意节点使用用kubectl # 正常在node节点上是无法执行kubectl命令 [rootk8s-node-01 ~]# kubectl get pods The connection to the server localhost:8080 was refused - did you specify the right host or port?1、将master节点中/etc/kubernetes/,admin.conf拷…

性能分析5部曲:瓶颈分析与问题定位,如何快速解决瓶颈?

一、引言 很多做性能测试的同学都问过我这样一个问题&#xff1a;鱼哥(Carl_奕然)&#xff0c;你说性能测试的重点是什么? 我的回答很简单&#xff1a;瓶颈分析与问题定位。 在性能项目的整个周期&#xff0c;不管是脚本设计&#xff0c;脚本编写还是脚本执行&#xff0c;都…