Leetcode - 128双周赛

news2024/11/26 14:25:55

目录

一,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]){//跟新右端点和ans
                r = 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路径为0
        boolean[] 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});
            else
                que.addLast(new int[]{num, 1});
            ans += que.getLast()[1];
        }
        return ans;
    }
}

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

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

相关文章

⑤【Shiro】SpringBoot整合Shiro,实现登录认证

个人简介&#xff1a;Java领域新星创作者&#xff1b;阿里云技术博主、星级博主、专家博主&#xff1b;正在Java学习的路上摸爬滚打&#xff0c;记录学习的过程~ 个人主页&#xff1a;.29.的博客 学习社区&#xff1a;进去逛一逛~ ⑤【Shiro】SpringBoot整合Shiro&#xff0c;实…

作为Boss,还在写代码。what?赶紧改掉这个坏毛病

有些创业中的老板&#xff0c;经常或者偶尔也要写代码&#xff0c;我听了很震惊呀&#xff0c;这叫创业吗&#xff1f;这不是给员工打工吗&#xff1f;其他重要的事情谁来干&#xff0c;这个毛病一定要改。 一、比起写代码&#xff0c;你还有更重要的事情要做 作为BOSS和创业…

.NET 爬虫从入门到入狱

目录 前言 1.&#x1f4a1;使用HttpClient爬取数据 2.&#x1f680;模拟User-Agent 3.&#x1f935;使用HTML解析库 3.&#x1f44c;前端Price显示 4.&#x1f331;运行实例 获取金价Au 5.&#x1f9fe;使用正则表达式解析 6.&#x1f4ab;获取BTC价格 7.✨获取CSDN热点…

【网站项目】书籍销售系统小程序

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

【云计算】安全组和网络ACL的区别

安全组和网络ACL的区别 ACL&#xff08;Access Control List&#xff09;和 安全组&#xff08;Security Group&#xff09;是两种不同的网络安全控制机制&#xff0c;通常用于管理云计算平台中的网络访问权限。它们在功能和实现上有一些显著的区别&#xff1a; 辨析 范围不同&…

大数据------额外插件及技术------Git(完整知识点汇总)

Git 定义 它是分布式版本控制工具&#xff0c;主要用于管理开发过程中的源代码文件&#xff08;如&#xff1a;Java类、xml文件、html页面等&#xff09;&#xff0c;在软件开发过程中被广泛应用 作用 代码回溯&#xff1a;快速回到某一代码历史版本版本切换&#xff1a;同一个…

【深度学习】Attention、Self-Attention、Multi-Head Attention

一、Attention 在CV领域&#xff0c;注意力机制通常分为通道注意力和空间注意力或者两者结合。 一张图像经backbone得到的特征通常包括多个通道&#xff0c;每个通道是一个像素矩阵&#xff0c;每个通道对任务的贡献不尽相同&#xff0c;单个通道的特征图中每个像素对任务的贡…

户外旅行摄影手册,旅游摄影完全攻略

一、资料前言 本套旅游摄影资料&#xff0c;大小295.47M&#xff0c;共有9个文件。 二、资料目录 《川藏线旅游摄影》杨桦.彩印版.pdf 《户外摄影指南》(Essential.Guide.to.Outdoor.photography.amateur)影印版.pdf 《旅行摄影大师班》(英)科尼什.扫描版.PDF 《旅行摄影…

Java垃圾回收1

1.对象什么时候可以被垃圾器回收 1.垃圾回收的概念 为了让程序员更专注于代码的实现&#xff0c;而不用过多的考虑内存释放的问题&#xff0c;所以&#xff0c; 在Java语言中&#xff0c;有了自动的垃圾回收机制&#xff0c;也就是我们熟悉的GC(Garbage Collection)。 有了垃圾…

网络编程ServerSocketChannel

ServerSocketChannel 1 非阻塞 vs 阻塞1.1 阻塞1.2 非阻塞1.3 多路复用 2 Selector2.1 创建2.2 绑定 Channel 事件2.3 监听 Channel 事件2.4 &#x1f4a1; select 何时不阻塞 3 处理 accept 事件&#x1f4a1; 事件发生后能否不处理 4 处理 read 事件4.1 &#x1f4a1; 为何要…

vscode绿绿主题setting config

下载插件Green Tree Theme 选greentree ctrl shift p找到setting {"workbench.colorTheme": "Green Tree","editor.fontSize": 16.5, // 字号"workbench.colorCustomizations": {"[Green Tree]": {"activityBarBadge.…

【Lattice FPGA 开发】Modelsim与Diamond联合仿真

本文讲解Modelsim与Diamond进行联合仿真步骤&#xff0c;以及对遇到问题的解决与说明。 文章目录 软件版本0. Diamond设置文件为仿真文件特别注意 1. Diamond设置仿真软件为Modelsim2. Modelsim编译Lattice的库文件2.1 新建文件夹存放库文件2.2 Modelsim中建立新的仿真库2.2.1…

探秘Redis:从数据类型到API

欢迎大家关注我的微信公众号“软件求生”,我们将会定期为大家带来更多有趣的技术分享和实用的开发技巧。感谢大家的支持! 大家好,我是小米,今天我们来聊一聊阿里巴巴面试中经常会遇到的一个热门话题——Redis数据类型和相关API。Redis作为一款高性能的键值对存储数据库,其…

LevelDB源码阅读笔记(1、整体架构)

LevelDB源码阅读笔记&#xff08;1、整体架构&#xff09; LeveDB源码笔记系列&#xff1a; LevelDB源码阅读笔记&#xff08;0、下载编译leveldb&#xff09; LevelDB源码阅读笔记&#xff08;1、整体架构&#xff09; 前言 对LevelDB源码的博客&#xff0c;我准备采用总…

HZNUCTF第五届校赛实践赛初赛 Web方向 WriteUp

ezssti 很简单的ssti 源码给了&#xff0c;调用Eval即可执行命令 package mainimport ("fmt""net/http""os/exec""strings""text/template" )type User struct {Id intName stringPasswd string }func (u User) Ev…

短视频去水印解析接口 可测试

短视频解析聚合接口80多个热们短视频平台。可测试 接口开发文档&#xff1a; 返回格式&#xff1a; JSON 请求方式&#xff1a; GET/POST 示例请求地址&#xff1a;https://www.dspqsy.vip/spapi?keykey&url短视频url 请求参数说明&#xff1a; 字段必填类型说明url是…

Golang | Leetcode Golang题解之第36题有效的数独

题目&#xff1a; 题解&#xff1a; func isValidSudoku(board [][]byte) bool {var rows, columns [9][9]intvar subboxes [3][3][9]intfor i, row : range board {for j, c : range row {if c . {continue}index : c - 1rows[i][index]columns[j][index]subboxes[i/3][j/3]…

2021年全国大学生电子设计竞赛D题——基于互联网的摄像测量系统(二)

09 电路设计 前面介绍了系统的硬件框图如下&#xff1a; 硬件基本分为三块&#xff0c;两个摄像节点&#xff0c;一个终端节点。 1. 摄像节点硬件 摄像节点由一个DE10-Nano开发板和一个D8M摄像头实现&#xff0c;DE10-Nano开发板的HDMI接口外接HDMI显示器来显示拍摄到的视频。…

Linux下SPI设备驱动实验:验证读写SPI设备中数据的函数功能

一. 简介 前面文章实现了 SPI设备驱动框架&#xff0c;并在此基础上添加了字符设备驱动框架&#xff0c;实现了读 / 写SPI设备中数据的函数&#xff0c;文章如下&#xff1a; Linux下SPI设备驱动实验&#xff1a;向SPI驱动框架中加入字符设备驱动框架代码-CSDN博客 Linux下…

基于springboot实现工程教育认证的计算机课程管理平台项目【项目源码+论文说明】

基于springboot实现计算机课程管理平台系统演示 摘要 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;管理信息系统的实施在技术上已逐步成熟。本文介绍了基于工程教育认证的计算机课程管理平台的开发全过程。通过分析基于工程教育认证的计算机课程管理平台管理的不足…