剑指offer面试题15:链表中倒数第K个节点
生活随笔
收集整理的這篇文章主要介紹了
剑指offer面试题15:链表中倒数第K个节点
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
題目:輸入一個鏈表,輸出該鏈表的倒數第K個節點。為了符合大多數人的習慣,本題從1開始計數,即鏈表尾節點是倒數第一個節點。
解題思路: 解法一:一般情況下,單向鏈表無法從后一個節點獲取到它前面的節點,可以通過兩次遍歷,第一次遍歷獲取鏈表中節點的個數,第二次遍歷找到鏈表中第n-k+1個節點,就是鏈表的倒數第k個節點。
但是這種方法效率低,可以使用一次遍歷得到倒數第K個節點 解法二:一次遍歷得到倒數第K個節點。維護兩個指針,第一個指針從鏈表頭結點向前走k-1步,第二個節點指向頭結點,從第K步開始,如果走在前面的節點有下一個節點,那兩個節點一起向前走,
直到第一個節點走到尾節點,此時第二個節點指向倒數第K個節點
程序健壯性考慮: 1.輸入鏈表為null 2.輸入k為0或小于0 3.鏈表節點總數小于k
1 package Solution; 2 3 public class No15FindKthNodeFromEnd { 4 5 public static class ListNode { 6 int data; 7 ListNode next; 8 9 public ListNode(int value, ListNode next) { 10 this.data = value; 11 this.next = next; 12 } 13 } 14 15 public static ListNode findKthNodeFromEnd(ListNode head, int k) { 16 if (head == null) 17 throw new RuntimeException("待查找的鏈表不能為空"); 18 if (k <= 0) 19 throw new RuntimeException("輸入的位置數字不合法"); 20 ListNode ahead = head; 21 ListNode behind = head; 22 // 第一個指針先指向K-1,并檢驗鏈表中節點個數是否大于k 23 int count = 1; 24 for (int i = 0; i < k - 1; i++) { 25 if (ahead.next != null) { 26 ahead = ahead.next; 27 count++; 28 } else 29 throw new RuntimeException("鏈表節點個數:" + count + " 小于輸入K的個數:" + k); 30 } 31 while (ahead.next != null) { 32 ahead = ahead.next; 33 behind = behind.next; 34 } 35 return behind; 36 } 37 38 public static void main(String[] args) { 39 ListNode node1 = new ListNode(4, null); 40 ListNode node2 = new ListNode(3, node1); 41 ListNode node3 = new ListNode(2, node2); 42 ListNode head = new ListNode(1, node3); 43 ListNode find = findKthNodeFromEnd(head, 3); 44 System.out.println("找到的節點位" + find.data); 45 ListNode find2 = findKthNodeFromEnd(head, 5); 46 System.out.println("找到的節點位" + find2.data); 47 } 48 }
解題思路: 解法一:一般情況下,單向鏈表無法從后一個節點獲取到它前面的節點,可以通過兩次遍歷,第一次遍歷獲取鏈表中節點的個數,第二次遍歷找到鏈表中第n-k+1個節點,就是鏈表的倒數第k個節點。
但是這種方法效率低,可以使用一次遍歷得到倒數第K個節點 解法二:一次遍歷得到倒數第K個節點。維護兩個指針,第一個指針從鏈表頭結點向前走k-1步,第二個節點指向頭結點,從第K步開始,如果走在前面的節點有下一個節點,那兩個節點一起向前走,
直到第一個節點走到尾節點,此時第二個節點指向倒數第K個節點
程序健壯性考慮: 1.輸入鏈表為null 2.輸入k為0或小于0 3.鏈表節點總數小于k
1 package Solution; 2 3 public class No15FindKthNodeFromEnd { 4 5 public static class ListNode { 6 int data; 7 ListNode next; 8 9 public ListNode(int value, ListNode next) { 10 this.data = value; 11 this.next = next; 12 } 13 } 14 15 public static ListNode findKthNodeFromEnd(ListNode head, int k) { 16 if (head == null) 17 throw new RuntimeException("待查找的鏈表不能為空"); 18 if (k <= 0) 19 throw new RuntimeException("輸入的位置數字不合法"); 20 ListNode ahead = head; 21 ListNode behind = head; 22 // 第一個指針先指向K-1,并檢驗鏈表中節點個數是否大于k 23 int count = 1; 24 for (int i = 0; i < k - 1; i++) { 25 if (ahead.next != null) { 26 ahead = ahead.next; 27 count++; 28 } else 29 throw new RuntimeException("鏈表節點個數:" + count + " 小于輸入K的個數:" + k); 30 } 31 while (ahead.next != null) { 32 ahead = ahead.next; 33 behind = behind.next; 34 } 35 return behind; 36 } 37 38 public static void main(String[] args) { 39 ListNode node1 = new ListNode(4, null); 40 ListNode node2 = new ListNode(3, node1); 41 ListNode node3 = new ListNode(2, node2); 42 ListNode head = new ListNode(1, node3); 43 ListNode find = findKthNodeFromEnd(head, 3); 44 System.out.println("找到的節點位" + find.data); 45 ListNode find2 = findKthNodeFromEnd(head, 5); 46 System.out.println("找到的節點位" + find2.data); 47 } 48 }
?
轉載于:https://www.cnblogs.com/gl-developer/p/7237040.html
與50位技術專家面對面20年技術見證,附贈技術全景圖總結
以上是生活随笔為你收集整理的剑指offer面试题15:链表中倒数第K个节点的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 基于文件组备份还原
- 下一篇: 自然语言处理(四)统计机器翻译SMT