欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何利用Java輸出鏈表中倒數(shù)第k個(gè)結(jié)點(diǎn)

 更新時(shí)間:2021年12月10日 10:19:47   作者:WYSCODER  
這篇文章主要給大家介紹了關(guān)于如何利用Java輸出鏈表中倒數(shù)第k個(gè)結(jié)點(diǎn)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

前言

鏈表是一種數(shù)據(jù)結(jié)構(gòu),和數(shù)組同級(jí)。比如,Java中我們使用的ArrayList,其實(shí)現(xiàn)原理是數(shù)組。而LinkedList的實(shí)現(xiàn)原理就是鏈表了。鏈表在進(jìn)行循環(huán)遍歷時(shí)效率不高,但是插入和刪除時(shí)優(yōu)勢明顯

本文主要介紹的是輸出鏈表中倒數(shù)第k個(gè)結(jié)點(diǎn),下面來一起看看詳細(xì)的介紹吧

問題描述

給你一個(gè)單鏈表,輸出倒數(shù)第k個(gè)結(jié)點(diǎn),如下圖鏈表中,輸出倒數(shù)第k個(gè)結(jié)點(diǎn),比如 k = 2,輸出5這個(gè)結(jié)點(diǎn)。

方法一

方法描述

輸出倒數(shù)第k個(gè)結(jié)點(diǎn)就是輸出整數(shù)第len - k + 1個(gè)結(jié)點(diǎn),len為鏈表的長度。

動(dòng)畫演示

代碼如下

/**
 * Definition for singly-linked list.
 * public class Node {
 *     int val;
 *     Node next;
 *     Node() {}
 *     Node(int val) { this.val = val; }
 *     Node(int val, Node next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    //計(jì)算鏈表的長度
    private int size() {
        int count = 0;
        for(Node p = head;p != null;p = p.next) {
        		count++;
        }
        return count;
    }
    //返回倒數(shù)第k個(gè)結(jié)點(diǎn)
    public Node outputLastIndexNode(int k) {
        //鏈表為空
        if (head == null) {
            return null;
        }
        
        //鏈表長度
        int len = size();
        //檢測k值
        if(k > len || k < 0) {
              System.out.println("k值有誤?。?!");
        }
      
      	Node p = head;
        for(int i = 0; i < len - k; i++) {
        	  p = p.next;
        }
        return p;
}

方法二

方法描述

1)定義一個(gè)q變量指向鏈表的第一個(gè)結(jié)點(diǎn),是q變量往后移動(dòng)k個(gè)結(jié)點(diǎn)。

2)定義一個(gè)p變量指向鏈表的第一個(gè)結(jié)點(diǎn)。

3)p變量和q變量同時(shí)循環(huán)往后移動(dòng)一個(gè)結(jié)點(diǎn),直到q為null。

動(dòng)畫演示

代碼如下

/**
 * Definition for singly-linked list.
 * public class Node {
 *     int val;
 *     Node next;
 *     Node() {}
 *     Node(int val) { this.val = val; }
 *     Node(int val, Node next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    //計(jì)算鏈表的長度
    private int size() {
        int count = 0;
        for(Node p = head;p != null;p = p.next) {
        		count++;
        }
        return count;
    }
    //返回倒數(shù)第k個(gè)結(jié)點(diǎn)
    public Node outputLastIndexNode(int k) {
        //鏈表為空
        if (head == null) {
            return null;
        }
        
        //鏈表長度
        int len = size();
        //檢測k值
        if(k > len || k < 0) {
              System.out.println("k值有誤?。。?);
        }
      
      	Node q = head;
      	//使q往后移動(dòng)k個(gè)結(jié)點(diǎn)
      	while(k-- > 0) {
      		q = q.next;
      	}
       	Node p = head;
       	while( q != null) {
       		q = q.next;
       		p = p.next;
        } 
		return p;	
}

總結(jié)

到此這篇關(guān)于如何利用Java輸出鏈表中倒數(shù)第k個(gè)結(jié)點(diǎn)的文章就介紹到這了,更多相關(guān)Java輸出鏈表結(jié)點(diǎn)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java中空指針異常該如何避免詳解

    Java中空指針異常該如何避免詳解

    空指針(Null Pointer Exception,NPE)是Java中最常見不過的異常了,其原因雖然顯而易見,但是開發(fā)人員往往會(huì)忽略,或未能及時(shí)采取措施,下面這篇文章主要給大家介紹了關(guān)于Java中空指針異常該如何避免的相關(guān)資料,需要的朋友可以參考下
    2022-03-03
  • JSP服務(wù)器端和前端出現(xiàn)亂碼問題解決方案

    JSP服務(wù)器端和前端出現(xiàn)亂碼問題解決方案

    這篇文章主要介紹了JSP服務(wù)器端和前端出現(xiàn)亂碼問題解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • 深入了解Java中String、Char和Int之間的相互轉(zhuǎn)換

    深入了解Java中String、Char和Int之間的相互轉(zhuǎn)換

    這篇文章主要介紹了深入了解Java中String、Char和Int之間的相互轉(zhuǎn)換,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,,需要的朋友可以參考下
    2019-06-06
  • Java實(shí)現(xiàn)在線預(yù)覽的示例代碼(openOffice實(shí)現(xiàn))

    Java實(shí)現(xiàn)在線預(yù)覽的示例代碼(openOffice實(shí)現(xiàn))

    本篇文章主要介紹了Java實(shí)現(xiàn)在線預(yù)覽的示例代碼(openOffice實(shí)現(xiàn)),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-11-11
  • tio-boot?jfinal-plugins框架整合redis示例詳解

    tio-boot?jfinal-plugins框架整合redis示例詳解

    這篇文章主要為大家介紹了tio-boot?jfinal-plugins框架整合redis示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • 詳解Java分布式緩存系統(tǒng)中必須解決的四大問題

    詳解Java分布式緩存系統(tǒng)中必須解決的四大問題

    分布式緩存系統(tǒng)是三高架構(gòu)中不可或缺的部分,極大地提高了整個(gè)項(xiàng)目的并發(fā)量、響應(yīng)速度,但它也帶來了新的需要解決的問題,分別是: 緩存穿透、緩存擊穿、緩存雪崩和緩存一致性問題。本文將詳細(xì)講解一下這四大問題,需要的可以參考一下
    2022-04-04
  • 最新評(píng)論