【Java--数据结构】链表经典OJ题详解(上)
创始人
2024-11-10 16:04:43

欢迎关注个人主页:逸狼


创造不易,可以点点赞吗~

如有错误,欢迎指出~



目录

谈谈头插、头删、尾插、头插的时间复杂度

反转一个单链表 

链表的中间结点

返回倒数第k个结点

合并两个链表


谈谈头插、头删、尾插、头插的时间复杂度

头插和头删的时间复杂度为O(1),

尾插和尾删的时间复杂度为O(n) (因为尾插和尾删要一个个遍历完链表)

反转一个单链表 

OJ链接

采用头插法

创建cur指针使得cur=head.next

将head.next置空(作为尾节点)(注意要判断head为空的情况,return head,否则会报空指针异常)

  1. 创建curN指针使得curN=cur.next
  2. 让cur.next=head
  3. head=cur

1~3步是一个循环,进入循环条件是cur!=null(即当cur为空时,代表cur已经遍历完链表)

 class Solution {     public ListNode reverseList(ListNode head) {         if(head==null){             return head;         }         //正常情况         ListNode cur=head.next;         head.next=null;         while(cur!=null){             ListNode curN=cur.next;             cur.next=head;             head=cur;             cur=curN;         }         return head;     } }

链表的中间结点

给定一个带有头结点 head 的非空单链表,返回链表的中间结点。如果有两个中间结点,则返回第二个中间结 点。OJ链接

 快慢指针法

定义一个慢指针slow(每次走一步),一个快指针fast(每次走两步)

  • 即slow=slow.next
  • fast=fast.next.next

这是一个循环,进入循环的条件为fast!=null&&fast.next!=null(这两个条件不可以交换,否则当fast=null时,先判断fast.next!=null时,会出现空指针异常)

fast!=null针对的是链表长度是数的情况

fast.next!=null针对的是链表长度是数的情况

class Solution {     public ListNode middleNode(ListNode head) {          ListNode slow=head;         ListNode fast=head;         while(fast!=null&&fast.next!=null){             slow=slow.next;             fast=fast.next.next;         }         return slow;     } }

返回倒数第k个结点

输入一个链表,输出该链表中倒数第k个结点。OJ链接

 定义两个节点fast和slow,先让fast走k步,再让fast和slow一起走,当fast走完链表时,此时slow的位置就是倒数第k个节点。(fast和slow之间的距离就是k,当fast走到null时,返回slow.val)

 

fast先走k步,用count计数,

  • fast=fast.next
  • count++

这是一个循环,条件是count

接着让fast和slow一起走,进入循环条件是fast!=null

  • fast=fast.next
  • slow=slow.next
class Solution {     public int kthToLast(ListNode head, int k) {         ListNode fast=head;         ListNode slow =head;         int count=0;         while(count

合并两个链表

将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。OJ 链接

定义一个哨兵位节点newH,遍历节点tmp

比较A和B链表的值,谁小,就将谁的节点放入新链表中

若A的值小( B同理)

  • tmp.next=headA;
  • headA=headA.next;
  • tmp=tmp.next;

这是一个循环,进入循环条件是headA!=null&&headB!=null(只要有一个链表遍历完了,就跳出循环)

还要判断A走完,B还有的情况(headA=null),(反之同理)

tmp.next=headB;

class Solution {     public ListNode mergeTwoLists(ListNode list1, ListNode list2) {         ListNode headH=new ListNode();         ListNode cur=headH;                  while(list1!=null&&list2!=null){             if(list1.val

相关内容

热门资讯

裸辞做“一人公司”,我后悔了 去年这个时候,一位以色列程序员正在东南亚旅行。他顺手把一个在脑子里转了很久的想法做成了产品,一个让任...
南京建成国内首个Pre-6G试... 4月21日,2026全球6G技术与产业生态大会在南京开幕。全息互动技术展台前,一名远在北京的工作人员...
超梵求职受邀参加“2025抖音... 超梵求职受邀参加“2025抖音巨量引擎成人教育行业生态大会”,探讨分享优质内容传播,服务万千学员。 ...
摩托罗拉Razr 2026(R... IT之家 4 月 22 日消息,摩托罗拉宣布新一代 Razr 折叠手机将于 4 月 29 日在美国发...
库克卸任,特纳斯领航:苹果新纪... 苹果首席执行官蒂姆·库克将卸任,硬件工程主管约翰·特纳斯将接任,苹果公司今天宣布此事。 库克将在夏季...