package case15_FindKthFromEnd;
public class FindKthFromEnd {
public static void main(String[] args) {
ListNode listNode1 = new ListNode(1);
ListNode listNode2 = new ListNode(2);
ListNode listNode3 = new ListNode(3);
ListNode listNode4 = new ListNode(4);
ListNode listNode5 = new ListNode(5);
ListNode listNode6 = new ListNode(6);
ListNode listNode7 = new ListNode(7);
listNode1.next = listNode2;
listNode2.next = listNode3;
listNode3.next = listNode4;
listNode4.next = listNode5;
listNode5.next = listNode6;
listNode6.next = listNode7;
listNode7.next = null;
//方法1:一次遍历,通过两个距离为K-1的方式控制
int temp = findKthNodeFromEnd(listNode1, 7).val;
System.out.println(temp);
//方法2:两次遍历
temp = findKthNodeFromEnd2(listNode1, 7).val;
System.out.println(temp);
}
// 构造节点结构
public static class ListNode {
int val;
ListNode next = null;
public ListNode(int val) {
this.val = val;
}
}
// 方法1:一次遍历,通过两个相聚为K-1的变量获得倒数第k个节点
public static ListNode findKthNodeFromEnd(ListNode listN1, int k) {
// 空链表或者k为0
ListNode firstNode = listN1;
ListNode secondeNode = null;
if (listN1 == null || k == 0) {
return null;
}
// 考虑节点总数少于k
for (int i = 0; i < k-1; i++) {
if (firstNode.next != null)
firstNode = firstNode.next;
else
return null;
}
secondeNode = listN1;
while (firstNode.next != null) {
firstNode = firstNode.next;
secondeNode = secondeNode.next;
}
return secondeNode;
}
// 方法2:两次遍历
public static ListNode findKthNodeFromEnd2(ListNode listN2, int k) {
int totalNode = 0;
ListNode bakNode = listN2;
// 空链表或者k为0
if (listN2 == null || k == 0) {
return null;
}
// 遍历链表,获得总结点数
while (listN2 != null) {
totalNode++;
listN2 = listN2.next;
}
if (totalNode < k)
return null;
for (int j = 0; j < totalNode - k; j++) {
bakNode = bakNode.next;
}
return bakNode;
}
}
剑指offer-面试题15-链表中倒数第k个节点
最新推荐文章于 2021-05-18 17:01:19 发布