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

2024-03-29 02:12

本文主要是介绍力扣爆刷第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;}
}

这篇关于力扣爆刷第107天之CodeTop100五连刷21-25的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/857329

相关文章

随想录 Day 69 并查集 107. 寻找存在的路径

随想录 Day 69 并查集 107. 寻找存在的路径 理论基础 int n = 1005; // n根据题目中节点数量而定,一般比节点数量大一点就好vector<int> father = vector<int> (n, 0); // C++里的一种数组结构// 并查集初始化void init() {for (int i = 0; i < n; ++i) {father[i] = i;}

21.手绘Spring IOC运行时序图

1.再谈IOC与 DI IOC(lnversion of Control)控制反转:所谓控制反转,就是把原先我们代码里面需要实现的对象创 建、依赖的代码,反转给容器来帮忙实现。那么必然的我们需要创建一个容器,同时需要一种描述来让 容器知道需要创建的对象与对象的关系。这个描述最具体表现就是我们所看到的配置文件。 DI(Dependency Injection)依赖注入:就是指对象是被动接受依赖类

力扣SQL50 每位经理的下属员工数量 join

Problem: 1731. 每位经理的下属员工数量 👨‍🏫 参考题解 Code select m.Employee_id, m.name,count(*) reports_count,round(avg(e.age),0) average_agefrom Employees ejoin Employees mon e.reports_to = m.Employee_id

PS系统教程25

介绍软件 BR(bridge) PS 配套软件,方便素材整理、管理素材 作用:起到桥梁作用 注意:PS和BR尽量保持版本一致 下载和安装可通过CSDN社区搜索,有免费安装指导。 安装之后,我们打开照片只需双击照片,就自动在Ps软件中打开。 前提:电脑上有PS软件 三种预览格式 全屏预览 评星级 直接按数字键就可以 方向键可以更换图片 esc退出 幻灯片放

6月21日训练 (东北林业大学)(个人题解)

前言:   这次训练是大一大二一起参加的训练,总体来说难度是有的,我和队友在比赛时间内就写出了四道题,之后陆陆续续又补了了三道题,还有一道题看了学长题解后感觉有点超出我的能力范围了,就留给以后的自己吧。话不多说,上正文。 正文:   Problem:A 幸运数字: #include <bits/stdc++.h>using namespace std;int sum,ans;in

【团队成长】2024-25周周报-业务介绍内容创作

大家好!我们是IndustryOR 团队,致力于分享业界落地的算法技术。欢迎关注微信公众号/知乎/CSDN【运筹匠心】 。 记录人:张哲铭,某互联网大厂算法专家 【团队成长/个人成长】系列的推文会以 【工作周报】 的方式记录IndustryOR团队及其成员的成长过程,请大家一起见证和参与我们团队从0-1-N的发展过程。 记录人顺序:张哲铭-向杜兵-高欣甜-黄世鸿-许佳鸣

力扣SQL50 游戏玩法分析 IV 子查询

Problem: 550. 游戏玩法分析 IV 👨‍🏫 参考题解 这个SQL查询的目的是计算每个玩家在登录后的第二天参与活动的比例。查询使用了子查询和左连接来实现这一目的。下面是查询的详细解释,包括每个部分的作用和注释: -- 计算每个玩家登录后第二天参与活动的比例select round(avg(a.event_date is not null), 2) as fractio

力扣-2663

题目 如果一个字符串满足以下条件,则称其为 美丽字符串 : 它由英语小写字母表的前 k 个字母组成。它不包含任何长度为 2 或更长的回文子字符串。 给你一个长度为 n 的美丽字符串 s 和一个正整数 k 。 请你找出并返回一个长度为 n 的美丽字符串,该字符串还满足:在字典序大于 s 的所有美丽字符串中字典序最小。如果不存在这样的字符串,则返回一个空字符串。 对于长度相同的两个字符串 a

力扣SQL50 超过5名学生的课

Problem: 596. 超过5名学生的课 Code select classfrom coursesgroup by classhaving count(distinct student) >= 5;

力扣刷题 杨辉三角(使用c++ vector解法)

杨辉三角 题目描述示例1示例2提示:代码 题目描述 给定一个非负整数 numRows,生成「杨辉三角」的前 numRows 行。 在「杨辉三角」中,每个数是它左上方和右上方的数的和。 示例1 输入: numRows = 5 输出: [[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]] 示例2 输入: numRows = 1