力扣爆刷第107天之CodeTop100五连刷21-25

力扣爆刷第107天之CodeTop100五连刷21-25

文章目录

      • 力扣爆刷第107天之CodeTop100五连刷21-25
      • 一、103. 二叉树的锯齿形层序遍历
      • 二、92. 反转链表 II
      • 三、54. 螺旋矩阵
      • 四、160. 相交链表
      • 五、23. 合并 K 个升序链表

一、103. 二叉树的锯齿形层序遍历

题目链接:https://leetcode.cn/problems/binary-tree-zigzag-level-order-traversal/description/
思路:本题要求每层先从左往右遍历,下一层从右往左,再往下一层又变成了从左往右遍历,就是这种交替遍历,其实层序遍历的方式我们不需要改变,只需要改变记录的方式,对于每层出队节点收集时,如果该层是要求正序,那么把元素从尾部添加进新队列,如果该层要求逆序,那就从头部添加进队列,因为尾插法是正序,头插法是逆序,遍历后,然后再把收集到的数据添加进总集合中即可。


class Solution {List<List<Integer>> arrayList = new ArrayList<>();LinkedList<TreeNode> queue = new LinkedList<>();public List<List<Integer>> zigzagLevelOrder(TreeNode root) {if(root == null) return arrayList;boolean flag = true;queue.add(root);while(!queue.isEmpty()) {int size = queue.size();LinkedList<Integer> list = new LinkedList<>();for(int i = 0; i < size; i++) {TreeNode node = queue.poll();if(flag) {list.addLast(node.val);}else{list.addFirst(node.val);}if(node.left != null) {queue.add(node.left);}if(node.right != null) {queue.add(node.right);}}flag = !flag;arrayList.add(new ArrayList(list));}return arrayList;}
}

二、92. 反转链表 II

题目链接:https://leetcode.cn/problems/reverse-linked-list-ii/description/
思路:翻转链表中的一个片段,没啥技术含量,定位到为止,然后头插法,然后拼接尾部。


class Solution {public ListNode reverseBetween(ListNode head, int left, int right) {ListNode root = new ListNode(-1, head);ListNode p = root, pro = root, pre = null, end = null;for(int i = 0; i < left; i++) {pro = p;p = p.next;}pro.next = null;end = p;for(int i = left; i <= right; i++) {pre = p.next;p.next = pro.next;pro.next = p;p = pre;}end.next = p;return root.next;}
}

三、54. 螺旋矩阵

题目链接:https://leetcode.cn/problems/spiral-matrix/description/
思路:螺旋矩阵,控制上下左右边界,例如只要上边界小于等于下边界,就可以读取一行,如果左边界小于等于右边,就可以读取一列。

class Solution {List<Integer> spiralOrder(int[][] matrix) {List<Integer> list = new ArrayList<>();int m = matrix.length, n = matrix[0].length;int left = 0, right = n-1, up = 0, down = m-1;while(list.size() < m * n) {if(up <= down) {for(int i = left; i <= right; i++) {list.add(matrix[up][i]);}up++;}if(left <= right) {for(int i = up; i <= down; i++) {list.add(matrix[i][right]);}right--;}if(up <= down) {for(int i = right; i >= left; i--) {list.add(matrix[down][i]);}down--;}if(left <= right) {for(int i = down; i >= up; i--) {list.add(matrix[i][left]);}left++;}} return list;}
}

四、160. 相交链表

题目链接:https://leetcode.cn/problems/intersection-of-two-linked-lists/description/
思路:经典题目,两个链表都先求长度,然后遍历统一长度,然后同步遍历即可。


public class Solution {public ListNode getIntersectionNode(ListNode headA, ListNode headB) {ListNode pa = headA, pb = headB;int lenA = 0, lenB = 0;while(pa != null) {pa = pa.next;lenA++;}while(pb != null) {pb = pb.next;lenB++;}pa = headA;pb = headB;while(lenA < lenB) {pb = pb.next;lenB--;}while(lenA > lenB) {pa = pa.next;lenA--;}while(pa != null) {if(pa == pb) return pa;pa = pa.next;pb = pb.next;}return null;}
}

五、23. 合并 K 个升序链表

题目链接:https://leetcode.cn/problems/merge-k-sorted-lists/description/
思路:采用优先级队列,链表按照头部节点进行优先级排序,出队后然后再入队,然后一直出队统计即可。


class Solution {
public ListNode mergeKLists(ListNode[] lists) {PriorityQueue<ListNode> queue = new PriorityQueue<>((a, b) -> a.val-b.val);for(ListNode node : lists) {if(node != null) {queue.add(node);}}ListNode root = new ListNode();ListNode p = root;while(!queue.isEmpty()) {ListNode node = queue.poll();p.next = node;p = p.next;if(node.next != null) {queue.add(node.next);}}return root.next;}
}

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

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

相关文章

详解IOS的Automatically Sign在设备上打包

大家好我是咕噜美乐蒂&#xff0c;很高兴又和大家见面了&#xff01; "Automatically Sign" 是 Xcode 提供的一个功能&#xff0c;用于简化在设备上打包和签名应用的流程。通过使用 "Automatically Sign"&#xff0c;开发者可以在 Xcode 中轻松地进行应用…

QT基本数据类型

第一章QT基本数据类型 文章目录 第一章QT基本数据类型1.基础类型2. log输出基本分类格式化日志普通格式化条件格式化环境变量格式化禁用输出 3.字符串类型 1.基础类型 Qt基本数据类型定义在#include <QtGlobal>中&#xff0c;Qt基本数据类型有&#xff1a; 类型名称注释…

Gitlab 实现仓库完全迁移,包括所有提交记录、分支、标签

1 方案一&#xff1a;命令 cd <项目目录> git fetch --all git fetch --tags git remote rename origin old-origin #可以不保留 git remote add origin http://***(项目的新仓库地址) #git remote set-url origin <项目的新仓库地址> git push origin --all git…

FastAPI+React全栈开发04 FastAPI概述

Chapter01 Web Development and the FARM Stack 04 Introducing FastAPI FastAPIReact全栈开发04 FastAPI概述 Now we will look at a brief introducion to the Python REST-API framework of choice - FastAPI. Additionally, we will go over a high-level overview of t…

项目管理:项目进度管理的五大关键步骤

作为项目经理&#xff0c;要想做好项目进度管理&#xff0c;可以遵循以下五个关键步骤&#xff1a; 一、确定范围和分解目标 1、明确项目目标&#xff1a;首先&#xff0c;要清晰地定义项目的总体目标和预期成果。 2、范围界定&#xff1a;详细列出项目所需完成的所有任务和…

LDL^H分解求逆矩阵与MATLAB仿真(Right-Looking)

通过分解将对称正定厄米特矩阵分解成下三角矩阵L和对角矩阵D来求其逆矩阵 目录 前言 一、LDL^H基本算法 二、LDL^H Right-Looking算法 三、D矩阵求逆 四、L矩阵求逆 五、A矩阵求逆 六、计算量分析 七、MATLAB仿真 八、参考资料 总结 前言 在线性代数中&#xff0c;LDL…

HarmonyOS入门--配置环境 + IDE汉化

文章目录 下载安装DevEco Studio配置环境先认识DevEco Studio界面工程目录工程级目录模块级目录 app.json5module.json5main_pages.json通知栏预览区 运行模拟器IED汉化 下载安装DevEco Studio 去官网下载DevEco Studio完了安装 配置环境 打开已安装的DevEco Studio快捷方式…

Java中有哪些容器(集合类)?

Java中的集合类主要由Collection和Map这两个接口派生而出&#xff0c;其中Collection接口又派生出三个子接 口&#xff0c;分别是Set、List、Queue。所有的Java集合类&#xff0c;都是Set、List、Queue、Map这四个接口的实现 类&#xff0c;这四个接口将集合分成了四大类&#…

蓝桥杯 - 小明的背包1(01背包)

解题思路&#xff1a; 本题属于01背包问题&#xff0c;使用动态规划 dp[ j ]表示容量为 j 的背包的最大价值 注意&#xff1a; 需要时刻提醒自己dp[ j ]代表的含义&#xff0c;不然容易晕头转向 注意越界问题&#xff0c;且 j 需要倒序遍历 如果正序遍历 dp[1] dp[1 - vo…

Android应用程序的概念性描述

1.概述 Android 应用程序包含了工程文件、代码和各种资源&#xff0c;主要由 Java 语言编写&#xff0c;每一个应用程序将被编译成Android 的一个 Java 应用程序包&#xff08;*.apk&#xff09;。 由于 Android 系统本身是基于 Linux 操作系统运行的&#xff0c;因此 …

SpringBoot Redis 之Lettuce 驱动

一、前言 一直以为SpringBoot中 spring-boot-starter-data-redis使用的是Jredis连接池&#xff0c;直到昨天在部署报价系统生产环境时&#xff0c;因为端口配置错误造成无法连接&#xff0c;发现报错信息如下&#xff1a; 一了解才知道在SpringBoot2.X以后默认是使用Lettuce作…

蓝桥杯 2022 省A 选数异或

一种比较无脑暴力点的方法&#xff0c;时间复杂度是(nm)。 (注意的优先级比^高&#xff0c;记得加括号(a[i]^a[j])x&#xff09; #include <iostream> #include <vector> #include <bits/stdc.h> // 包含一些 C 标准库中未包含的特定实现的函数的头文件 usi…

使用脚本进行编译安装nginx和安装mysql

1. 编译安装nginx # 先看有没有安装nginx&#xff0c;然后安装&#xff0c;创建用户&#xff0c;启动cat <<EOF 功能&#xff1a; 1、编译安装nginx 2、初始化功能 3、清理安装环境 4、选择是否启动nginx EOF# 检查是否安装nginx nginx_pathfind / -name *nginx if [ -n…

成都市酷客焕学新媒体科技有限公司:实现品牌的更大价值!

成都市酷客焕学新媒体科技有限公司专注于短视频营销&#xff0c;深知短视频在社交媒体中的巨大影响力。该公司巧妙地将品牌信息融入富有创意和趣味性的内容中&#xff0c;使观众在轻松愉悦的氛围中接受并传播这些信息。凭借独特的创意和精准的营销策略&#xff0c;成都市酷客焕…

第二证券|打新股有风险吗?

打新股有危险&#xff0c;其主要危险是破发&#xff0c;其间呈现以下状况&#xff0c;新股可能会破发&#xff1a; 1、估值过高 新股的估值过高&#xff0c;与其价值不相契合&#xff0c;其泡沫性较大&#xff0c;然后导致个股在上市之后&#xff0c;稳健投资者以及主力大量地…

maven3.8.1开始不支持http私有库

问题 since maven 3.8.1 http repositories are blocked. 意思是从maven3.8.1版本开始&#xff0c;maven不在认http的私有库&#xff0c;它觉得http私有库不安全。 解决 我直接回退到maven3.8.1之前一个版本&#xff0c;maven3.6.3。我不想去研究settings.xml怎么去配置放心…

10个替代Sketch的软件大盘点!第一款震撼来袭!

Sketch是Mac平台上专门为用户界面设计的矢量图形绘制工具。Sketch简单的界面背后有优秀的矢量绘制能力和丰富的插件库。但遗憾的是&#xff0c;Sketch只能在Mac平台上使用和浏览&#xff0c;而且是本地化的工具&#xff0c;云共享功能并不完善。在本文中&#xff0c;我们评估了…

金三银四面试题(一):JVM类加载与垃圾回收

面试过程中最经典的一题&#xff1a; 请你讲讲在JVM中类的加载过程以及垃圾回收&#xff1f; 加载过程 当Java虚拟机&#xff08;JVM&#xff09;启动时&#xff0c;它会通过类加载器&#xff08;ClassLoader&#xff09;加载Java类到内存中。类加载是Java程序运行的重要组成…

最佳矢量绘图设计软件Sketch for Mac v99.5 最新中文激活版

Sketch for Mac是一款功能强大的矢量绘图软件&#xff0c;它提供了简单易用的界面和丰富的工具&#xff0c;让用户能够轻松创建精美的设计作品。 软件下载&#xff1a;Sketch for Mac v99.5 最新中文激活版 Sketch具有直观的布局和智能的工具&#xff0c;使得设计师能够快速实现…

python(一)网络爬取

在爬取网页信息时&#xff0c;需要注意网页爬虫规范文件robots.txt eg:csdn的爬虫规范文件 csdn.net/robots.txt User-agent: 下面的Disallow规则适用于所有爬虫&#xff08;即所有用户代理&#xff09;。星号*是一个通配符&#xff0c;表示“所有”。 Disallow&…