java單鏈表使用總結(jié)
鏈表的概念:
鏈表是一種物理存儲(chǔ)單元上非連續(xù)、非順序的存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過鏈表中的指針鏈接次序?qū)崿F(xiàn)的。鏈表由一系列節(jié)點(diǎn)(鏈表中的每一個(gè)元素稱為節(jié)點(diǎn))組成,節(jié)點(diǎn)可以在運(yùn)行時(shí)動(dòng)態(tài)生成。每個(gè)節(jié)點(diǎn)包含兩個(gè)部分:一個(gè)是存儲(chǔ)數(shù)據(jù)元素的數(shù)據(jù)域,另一個(gè)是存儲(chǔ)下一個(gè)節(jié)點(diǎn)地址的指針域。相對(duì)于線性表順序結(jié)構(gòu),操作復(fù)雜。由于不必按順序存儲(chǔ),鏈表在插入的時(shí)候可以達(dá)到O(1)的復(fù)雜度,比另一種線性表順序表快得多,但查找一個(gè)節(jié)點(diǎn)或者訪問特定編號(hào)的節(jié)點(diǎn)則需要O(n)的時(shí)間,而線性表和順序表相應(yīng)的時(shí)間復(fù)雜度分別是O(logn)和O(1)。
鏈表的優(yōu)勢(shì)
不需要知道數(shù)據(jù)的大小,可以充分利用計(jì)算機(jī)內(nèi)存空間,實(shí)現(xiàn)靈活的內(nèi)存動(dòng)態(tài)管理
鏈表允許插入和移除表上任意位置上的節(jié)點(diǎn)(但是不允許隨機(jī)存取)
鏈表的缺點(diǎn)
不能像數(shù)組一樣隨機(jī)讀取
增加了空間的開銷(增加了節(jié)點(diǎn)的指針域)
代碼實(shí)現(xiàn)
定義一個(gè)節(jié)點(diǎn)類
public class ListNode {//定義節(jié)點(diǎn)類 ? ? int val; ? ? ListNode next; ? ? ? ListNode(int x) { ? ? ? ? val = x; ? ? } ? ? ? //將數(shù)組的值賦給鏈表 ? ? public ListNode getList(int[] sums) { ? ? ? ? ListNode dummyHead = new ListNode(0); ? ? ? ? ListNode curr = dummyHead; ? ? ? ? for (int i = 0; i < sums.length; i++) { ? ? ? ? ? ? curr.next = new ListNode(sums[i]); ? ? ? ? ? ? curr = curr.next; ? ? ? ? } ? ? ? ? return dummyHead.next; ? ? } ? ? ? //將鏈表的值賦給list并打印 ? ? public void showList(ListNode listNode) { ? ? ? ? List list = new ArrayList(); ? ? ? ? while (listNode != null) { ? ? ? ? ? ? list.add(listNode.val); ? ? ? ? ? ? listNode = listNode.next; ? ? ? ? } ? ? ? ? for (int i = 0; i < list.size(); i++) { ? ? ? ? ? ? System.out.println(list.get(i)); ? ? ? ? } ? ? } ? ? ? /** ? ? ?* leetcode第二題 ? ? ?* ? ? ?* 給出兩個(gè)非空的鏈表用來表示兩個(gè)非負(fù)的整數(shù), ? ? ?* 其中,它們各自的位數(shù)是按照逆序的方式存儲(chǔ)的, ? ? ?* 并且它們的每一個(gè)節(jié)點(diǎn)只能存儲(chǔ)一位數(shù)組。 ? ? ?* @param l1 ? ? ?* @param l2 ? ? ?* @return ? ? ?*/ ? ? public ListNode addTwoNumbers(ListNode l1, ListNode l2) { ? ? ? ? ListNode dummyHead = new ListNode(0); ? ? ? ? ListNode p = l1, q = l2, curr = dummyHead; ? ? ? ? int carry = 0; ? ? ? ? while (p != null || q != null) { ? ? ? ? ? ? int x = (p != null) ? p.val : 0; ? ? ? ? ? ? int y = (q != null) ? q.val : 0; ? ? ? ? ? ? int sum = carry + x + y; ? ? ? ? ? ? carry = sum / 10; ? ? ? ? ? ? curr.next = new ListNode(sum % 10); ? ? ? ? ? ? curr = curr.next; ? ? ? ? ? ? if (p != null) p = p.next; ? ? ? ? ? ? if (q != null) q = q.next; ? ? ? ? } ? ? ? ? if (carry > 0) { ? ? ? ? ? ? curr.next = new ListNode(carry); ? ? ? ? } ? ? ? ? return dummyHead.next; ? ? } }
測(cè)試方法
public class main { ? ? public static void main(String[] args) { ? ? ? ? int a[] = {2, 4, 3}; ? ? ? ? int b[] = {5, 6, 4}; ? ? ? ? ListNode curr=new ListNode(0); ? ? ? ? ListNode l1=curr.getList(a); // ? ? ? ?curr.showList(l1); ? ? ? ? ListNode l2=curr.getList(b); // ? ? ? ?curr.showList(l2); ? ? ? ? ListNode l3=curr.addTwoNumbers(l1,l2); ? ? ? ? curr.showList(l3); ? ? } ? ? }
輸入[2,4,3],[5,6,4]
輸出[7,0,8]
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
springboot后端接收前端傳數(shù)組參數(shù)三種方法
這篇文章主要給大家介紹了關(guān)于springboot后端接收前端傳數(shù)組參數(shù)三種方法,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-07-07Java程序的初始化順序,static{}靜態(tài)代碼塊和實(shí)例語句塊的使用方式
這篇文章主要介紹了Java程序的初始化順序,static{}靜態(tài)代碼塊和實(shí)例語句塊的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01Netty分布式ByteBuf中PooledByteBufAllocator剖析
這篇文章主要為大家介紹了Netty分布式ByteBuf剖析PooledByteBufAllocator簡(jiǎn)述,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-03-03Java鏈表(Linked List)基本原理與實(shí)現(xiàn)方法入門示例
這篇文章主要介紹了Java鏈表(Linked List)基本原理與實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了Java鏈表(Linked List)的功能、原理、實(shí)現(xiàn)方法與操作注意事項(xiàng),需要的朋友可以參考下2020-03-03基于Spring AMQP實(shí)現(xiàn)消息隊(duì)列的示例代碼
Spring AMQP作為Spring框架的一部分,是一套用于支持高級(jí)消息隊(duì)列協(xié)議(AMQP)的工具,AMQP是一種強(qiáng)大的消息協(xié)議,旨在支持可靠的消息傳遞,本文給大家介紹了如何基于Spring AMQP實(shí)現(xiàn)消息隊(duì)列,需要的朋友可以參考下2024-03-03Spring中自定義數(shù)據(jù)類型轉(zhuǎn)換的方法詳解
Spring3引入了一個(gè)core.onvert包,提供一個(gè)通用類型轉(zhuǎn)換系統(tǒng)。在Spring容器中,可以使用這個(gè)系統(tǒng)作為PropertyEditor實(shí)現(xiàn)的替代,將外部化的bean屬性值字符串轉(zhuǎn)換為所需的屬性類型。本文將詳解這一系統(tǒng)的使用方法,需要的可以參考一下2022-06-06spring AOP定義AfterThrowing增加處理實(shí)例分析
這篇文章主要介紹了spring AOP定義AfterThrowing增加處理,結(jié)合實(shí)例形式分析了spring面向切面AOP定義AfterThrowing相關(guān)實(shí)現(xiàn)步驟與操作技巧,需要的朋友可以參考下2020-01-01spring-boot-maven-plugin?配置有啥用
這篇文章主要介紹了spring-boot-maven-plugin?配置是干啥的,這個(gè)是SpringBoot的Maven插件,主要用來打包的,通常打包成jar或者war文件,本文通過示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08