Leetcode - 128双周赛

目录

一,3110. 字符串的分数

二,3111. 覆盖所有点的最少矩形数目

三,3112. 访问消失节点的最少时间​编辑

写法一:朴素 Dijkstra(适用于稠密图,即边比较多的图)

写法二:堆优化 Dijkstra(适用于稀疏图,即边比较少的图)

四,3113. 边界元素是最大值的子数组数目


一,3110. 字符串的分数

本题就是求相邻字符差值绝对值的和,从下标1开始遍历,计算 i 和 i-1 的差值绝对值,将其加起来就是答案。 

代码如下: 

class Solution {public int scoreOfString(String s) {int ans = 0;for(int i=1; i<s.length(); i++){ans += Math.abs(s.charAt(i)-s.charAt(i-1));}return ans;}
}

二,3111. 覆盖所有点的最少矩形数目

仔细读题可以发现,其实这题与纵坐标没有关系,只需要关注横坐标就行了,所以题目就变成了在 x2 - x1 <= w 的情况下,最少需要几个线段才能覆盖所有横坐标。

该题需要对横坐标进行排序,再遍历横坐标,用一个变量 r 来统计在以 x 为左端点时最大的右端点,即 r = x + w,当有 xi > r 时,就说明需要添加一个线段ans++,跟新 r = xi + w,直到跳出循环,返回ans

代码如下:

class Solution {public int minRectanglesToCoverPoints(int[][] points, int w) {Arrays.sort(points, (x,y)->x[0]-y[0]);//排序int ans = 0;int r = -1;for(int i=0; i<points.length; i++){if(r < points[i][0]){//跟新右端点和ansr = points[i][0] + w;ans++;}}return ans;}
}

三,3112. 访问消失节点的最少时间

本题求点到点最短路径,一道标准的 djstra算法题(注:该算法不适用于有负权重的图),简单说一下djstra算法的思路:从初始点出发,选出与初始点相邻且距离最近的点,再从初始点和选出的点出发,选出相邻且距离最近的点。(注:每次选出一个点,且该点不是之前选过的点)

这么说有点抽象,画个图理解一下:

 

可以发现,每次都会找到一个A ->  ? 的最短路径,也就是说只要循环 n-1 次,就可以找到A点到其他所有点的最短路径。而在代码实现过程中需要两个数组,一个数组来统计该点是否被访问过,一个数组统计 A->? 的最短路径。

这里先介绍两种写法:

模板一:朴素 Dijkstra(适用于稠密图,即边比较多的图)

class Solution {public int moban(int n, int[][] edges) {//稠密图建图推荐使用数组建图//注:根据题目建图,这里建的是无向图int[][] g = new int[n][n];for(int i=0; i<n; i++)Arrays.fill(g[i], Integer.MAX_VALUE/2);for(int[] e : edges){int x = e[0], y = e[1], w = e[2];g[x][y] = w;g[y][x] = w;}int[] dis = new int[n];//存储从0->i节点的最短路径Arrays.fill(dis, Integer.MAX_VALUE/2);//防溢出dis[0] = 0;//0->0路径为0boolean[] vis = new boolean[n];//统计i点是否已经选择过for(int i=0; i<n-1; i++){int x = -1;for(int j=0; j<n; j++){//找出未访问过的距离A点最近的点if(!vis[j]&&(x==-1 || dis[j]<dis[x])){x = j;}}vis[x] = true;//该路径即为0->x的最短路径for(int y=0; y<n; y++){//更新0->y的最短路径dis[y] = Math.min(dis[y], dis[x]+g[x][y]);//注:虽然会遍历到已经访问过的点,但是不会对结果造成影响}}return dis;}
}

模板二:堆优化 Dijkstra(适用于稀疏图,即边比较少的图)

class Solution {public int[] moban(int n, int[][] edges) {//稀疏图建议使用链表建图//注:根据题目建图,这里是无向图List<int[]>[] g = new ArrayList[n];Arrays.setAll(g, e->new ArrayList<>());for(int[] e : edges){int x = e[0], y = e[1], w = e[2];g[x].add(new int[]{y, w});g[y].add(new int[]{x, w});}int[] dis = new int[n];//0->i的最短路径Arrays.fill(dis, -1);dis[0] = 0;PriorityQueue<int[]> que = new PriorityQueue<>((x,y)->x[0]-y[0]);//小根堆que.offer(new int[]{0, 0});//(t,j)->t:路径,j:节点while(!que.isEmpty()){int[] poll = que.poll();int dx = poll[0];int x = poll[1];if(dx > dis[x])//堆的懒删除continue;for(int[] y : g[x]){int newDis = dis[x] + y[1];if(dis[y[0]]==-1 || newDis < dis[y[0]]){//更新与x点相邻的点的最短路径dis[y[0]] = newDis;que.offer(new int[]{newDis, y[0]});}}}return dis;} 
}

 本题代码如下:

class Solution {public int[] minimumTime(int n, int[][] edges, int[] disappear) {List<int[]>[] g = new ArrayList[n];Arrays.setAll(g, e->new ArrayList<>());for(int[] e : edges){int x = e[0], y = e[1], w = e[2];g[x].add(new int[]{y, w});g[y].add(new int[]{x, w});}int[] dis = new int[n];Arrays.fill(dis, -1);dis[0] = 0;PriorityQueue<int[]> que = new PriorityQueue<>((x,y)->x[0]-y[0]);que.offer(new int[]{0, 0});//(t,j)->t:时间,j:节点while(!que.isEmpty()){int[] poll = que.poll();int dx = poll[0];int x = poll[1];if(dx > dis[x])continue;for(int[] y : g[x]){int newDis = dis[x] + y[1];//本题多了一个条件,所以这里多了个判断if(newDis < disappear[y[0]] && (dis[y[0]]==-1 || newDis < dis[y[0]])){dis[y[0]] = newDis;que.offer(new int[]{newDis, y[0]});}}}return dis;} 
}

四,3113. 边界元素是最大值的子数组数目

本题本质上还是一道单调栈的题,画个图理解一下:

从左往右依次遍历:

  • [1]时,有[1]成立
  • [1,4]时,多出[4]成立,这时候1就成了垃圾数据,因为如果包含1,那么这个数组不可能满足题意。删去1
  • [4,3]时,多出[3]成立,这时4不能删去,因为右端可能出现一个4,使其满足题意
  • [4,3,2]时,多出[2]成立,这时2不能删去,因为右端可能出现一个2,使其满足题意
  • [4,3,2,3]时,多出[3][3,2,3]成立,这时2就成了垃圾数据,因为如果包含2,那么这个数组不可能满足题意。删去2
  • [4,3,3,1]时,多出[1]

可以发现[4,3,3,1]是单调减的,所以可以使用单调栈来解决该问题。

代码如下:

class Solution {public long numberOfSubarrays(int[] nums) {long ans = 0;Deque<int[]> que = new ArrayDeque<>();que.add(new int[]{Integer.MAX_VALUE, 0});//防止que为空for(int num : nums){while(que.getLast()[0]<num){que.removeLast();}if(que.getLast()[0] == num)que.addLast(new int[]{num, que.getLast()[1]+1});elseque.addLast(new int[]{num, 1});ans += que.getLast()[1];}return ans;}
}

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

软考126-上午题-【软件工程】-测试方法

一、测试方法 在软件测试过程中&#xff0c;应该为定义软件测试模板&#xff0c;即将特定的测试方法和测试用例设计放在一系列的测试步骤中。 软件测试方法分为&#xff1a;静态测试和动态测试。 1-1、静态测试。 静态测试是指被测试程序不在机器上运行&#xff0c;而是采用…

js性能优化(五)

第五章开始啦~~~~~~~~~~~~~ 防抖和节流之前自己有学过一次&#xff0c;包括几种方式怎么实现&#xff0c;代码如何写花了两天有写过&#xff0c;这次算是更系统的一个复习加填补 十七、防抖与节流 为什么需要防抖和节流&#xff1a; 在一些高频率事件触发的场景下我们不希望…

【Redis深度解析】揭秘Cluster(集群):原理、机制与实战优化

Redis Cluster是Redis官方提供的分布式解决方案&#xff0c;通过数据分片与节点间通信机制&#xff0c;实现了水平扩展、高可用与数据容灾。本文将深入剖析Redis Cluster的工作原理、核心机制&#xff0c;并结合实战经验分享优化策略&#xff0c;为您打造坚实可靠的Redis分布式…

Leetcode二叉树刷题

给你一个二叉树的根节点 root &#xff0c; 检查它是否轴对称。 示例 1&#xff1a; 输入&#xff1a;root [1,2,2,3,4,4,3] 输出&#xff1a;true public boolean isSymmetric(TreeNode root) {if(rootnull)return true;return compare(root.left,root.right);}public boole…

浏览器渲染原理-解释回流重绘以及为什么transform效率高

浏览器是如何渲染页面 当浏览器的网络线程收到 HTML 文档后&#xff0c;会产生一个渲染任务&#xff0c;并将其传递给渲染主线程的消息队列。在事件循环机制的作用下&#xff0c;渲染主线程取出消息队列中的渲染任务&#xff0c;开启染流程。 整个渲染流程分为多个阶段&#xf…

家居网购项目(权限验证+事务管理)

文章目录 1.过滤器权限认证1.程序框架图2.web.xml3.编写AdminAuthorization4.编写MemberAuthorization5.细节6.结果展示1.未登录可以任意浏览商品2.点击添加购物车提示登录3.点击后台管理&#xff0c;提示管理员登录4.也做了其余资源的访问验证 2.事务管理1.思路分析2.重写JDBC…

git am XXX.patch 文件内容解析

git am XXX.patch 文件内容解析 打补丁的两种方式&#xff1a; 1.patch XXX.patch 2.git am XXX.patch 例如&#xff1a; diff --git a/drivers/crypto/se/ce.c b/drivers/crypto/se/ce.c index e6f68286d4ce6..de1bcb46fbe6b 100644 --- a/drivers/crypto/se/ce.cb/drive…

品牌百度百科词条创建多少钱?

百度百科作为国内最具权威和影响力的知识型平台&#xff0c;吸引了无数品牌和企业争相入驻。一个品牌的百度百科词条&#xff0c;不仅是对品牌形象的一种提升&#xff0c;更是增加品牌曝光度、提高品牌知名度的重要途径。品牌百度百科词条创建多少钱&#xff0c;这成为了许多企…

【vue】ref 和 reactive 对比

ref&#xff1a;存储单个数据&#xff0c;如数值&#xff0c;字符串reactive&#xff1a;存储复杂数据&#xff0c;如对象&#xff0c;数组 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"vie…

《QT实用小工具·二十六》运行时间记录

1、概述 源码放在文章末尾 运行时间记录&#xff0c;包含如下功能&#xff1a; 可以启动和停止服务&#xff0c;在需要的时候启动。 可以指定日志文件存放目录。 可以指定时间日志输出间隔。 可以单独追加一条记录到日志文件。 日志为文本格式&#xff0c;清晰明了。 软…

《前端面试题》- JS基础 - 伪数组

第一次听说伪数组这个概念&#xff0c;听到的时候还以为是说CSS的伪类呢&#xff0c;网上一查&#xff0c;这东西原来还是个很常见的家伙。 何为伪数组 伪数组有两个特点&#xff1a; 具有length属性&#xff0c;其他属性&#xff08;索引&#xff09;为非负整数但是却不具备…

使用DockerCompose配置基于哨兵模式的redis主从架构集群

文章目录 一、注意事项&#xff08;坑点&#xff01;&#xff01;&#xff01;&#xff09;二、配置Redis主从架构集群第一步&#xff1a;创建目录文件结构第二步&#xff1a;编写DockerCompose配置文件第三步&#xff1a;编写redis.conf第四步&#xff1a;启动redis主从集群 三…

Kubernetes 升级不弃 Docker:KubeKey 的丝滑之道

作者&#xff1a;尹珉&#xff0c;KubeSphere Ambaasador&Contributor&#xff0c;KubeSphere 社区用户委员会杭州站站长。 引言 随着 Kubernetes 社区的不断发展&#xff0c;即将迎来 Kubernetes 1.30 版本的迭代。在早先的 1.24 版本中&#xff0c;社区作出一个重要决策…

SysTick滴答定时器 - 延时函数

SysTick定时器 Systick定时器&#xff0c;是一个简单的定时器&#xff0c;对于CM3,CM4内核芯片&#xff0c;都有Systick定时器。Systick定时器常用来做延时&#xff0c;或者实时系统的心跳时钟。这样可以节省MCU资源&#xff0c;不用浪费一个定时器。比如UCOS中&#xff0c;分…

Windows10为Git Bash添加文件传输命令rsync(详细图文配置)

文章目录 1. 安装git bash2. 下载所需要的4个包3. 下载解压包的软件4. 复制每个包下面的usr到git安装目录下4.1 所遇问题4.2 解决 5. 安装完成6. 需要注意 Windows上要使用 rsync命令上传或下载文件&#xff0c;需要使用git bash&#xff0c;git bash没有rsync&#xff0c;需要…

MAC(M1芯片)编译Java项目慢且发热严重问题解决方案

目录 一、背景二、排查三、解决四、效果以及结果展示五、总结 一、背景 使用idea编译项目等操作&#xff0c;经常性发热严重&#xff0c;并且时间慢。直到昨天编译一个项目用时30分钟&#xff0c;电脑温度很高&#xff0c;并且有烧灼的味道&#xff0c;于是有了此篇文章。 二、…

Python的国际化和本地化【第162篇—国际化和本地化】

&#x1f47d;发现宝藏 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。【点击进入巨牛的人工智能学习网站】。 随着全球化的发展&#xff0c;多语言支持在软件开发中变得越来越重要。Python作为一种流行的…

VRRP——虚拟路由冗余协议

什么是VRRP 虚拟路由冗余协议VRRP&#xff08;Virtual Router Redundancy Protocol&#xff09;是一种用于提高网络可靠性的容错协议。 通过VRRP&#xff0c;可以在主机的下一跳设备出现故障时&#xff0c;及时将业务切换到备份设备&#xff0c;从而保障网络通信的连续性和可…

【vue】用vite创建vue项目

前置要求 要有Node.js 1. 用vite创建vue项目 在cmd中&#xff0c;进入一个文件夹 在文件资源管理器上面的文件目录中&#xff0c;输入cmd&#xff0c;回车在cmd中通过cd命令进入对应文件夹 创建项目 npm create vitelatest # 创建项目创建项目过程中的一些选项 Ok to pro…

06-vscode+espidf开发调试方法(内置JTAG调试)

使用VS Code和ESP-IDF进行ESP32开发和调试 在我们搭建 IDF 框架后&#xff0c;OpenOCD 已经自动下载好了&#xff0c; 我们通过 JTAG 接口连接使用 OpenOCD 进行调试。而ESP32芯片中内置 了JTAG 电路&#xff0c;无需额外芯片即可调试&#xff0c;更加方便&#xff0c;所以这里…