Java實(shí)現(xiàn)線性表的鏈?zhǔn)酱鎯?chǔ)
本文實(shí)例為大家分享了Java實(shí)現(xiàn)線性表的鏈?zhǔn)酱鎯?chǔ),供大家參考,具體內(nèi)容如下
鏈表:一種物理存儲(chǔ)結(jié)構(gòu)上非連續(xù)、非順序的存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過鏈表中的指針鏈接次序?qū)崿F(xiàn)的。
package algorithm.datastructure.linklist; import java.util.NoSuchElementException; /* * 鏈表 * 物理存儲(chǔ)上非連續(xù)的存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過鏈表中的指針鏈接次序?qū)崿F(xiàn) * * */ public class LinkedList { private Node head;//頭節(jié)點(diǎn) private int size;//鏈表長(zhǎng)度 static private class Node{ private int data; private Node next; public Node(){ } private Node(int data,Node next){ this.data=data; this.next=next; } } //初始化空鏈表 public LinkedList(){ //head=null; } //添加元素 public Boolean add(int element){ linkLast(element); return true; } //在某個(gè)位置之前添加元素 public Boolean add(int index,Integer element){ checkPositionIndex(index); if (index==size){ linkLast(element); } else { linkBefore(element,node(index)); } return true; } //根據(jù)下標(biāo)獲取元素 public int get(int index){ checkElementIndex(index); return node(index).data; } //獲取第一個(gè)元素 public Integer getFirst(){ Node f=head; if (f==null){ throw new NoSuchElementException(); } else { return f.data; } } //獲取最后一個(gè)元素 public Integer getLast(){ if (size==0){ throw new NoSuchElementException(); } int index=size-1; return node(index).data; } //刪除第一個(gè)元素 public Integer removeFirst(){ Node f=head; if (f==null){ throw new NoSuchElementException(); } else { return unlink(head); } } //刪除最后一個(gè)元素 public Integer removeLast(){ if (size==0){ throw new NoSuchElementException(); } int index=size-1; return unlink(node(index)); } //根據(jù)索引刪除元素 public Integer remove(int index){ checkElementIndex(index); return unlink(node(index)); } //銷毀鏈表 public void destroyList(){ clearList(); } //將鏈表置為空表 public void clearList() { for (Node p=head;p!=null;){ Node next=p.next;//記錄下一個(gè)結(jié)點(diǎn) p=null;//刪除當(dāng)前結(jié)點(diǎn) p=next;//指向下一個(gè)結(jié)點(diǎn) } size=0; head=null; } //遍歷鏈表 public void traverseList(){ for (Node p=head;p!=null;){ System.out.println(p.data); p=p.next; } } //返回鏈表元素個(gè)數(shù) public int size(){ return size; } //尾部添加結(jié)點(diǎn) private void linkLast(int element){ Node cur =null,p; if (size==0){//沒有結(jié)點(diǎn)時(shí) head=new Node(element,null); size++; return; } for (p=head;p!=null;){//有結(jié)點(diǎn)時(shí)候 cur=p; p=cur.next; } cur.next= new Node(element,null);//尾部添加元素 size++; } //在某結(jié)點(diǎn)之前插入結(jié)點(diǎn) private void linkBefore(int element,Node node){ if (node==null){ linkLast(element); } else { Node p=head,q=p.next; if (node.data==p.data){//node為結(jié)點(diǎn)時(shí)候 head= new Node(element, p);//在頭部插入元素 size++; } else { while (p!=null){ if (q.data==node.data) { p.next= new Node(element,q);//在q之前(p之后)插入一個(gè)元素 size++; break; } p=p.next; q=p.next; } } } } //刪除結(jié)點(diǎn) private Integer unlink(Node node){ Integer deleteNodeData=null; Node p=null; deleteNodeData=node.data; if (node.data==head.data){//該節(jié)點(diǎn)為頭結(jié)點(diǎn) p=head; head=p.next; p=null; size--; } else { Node q=head; for (p=q.next;p!=null;){//使用兩個(gè)指針,p,q if (p.data==node.data){ break; } q=q.next;//p始終為q的next結(jié)點(diǎn) p=q.next; } q.next=p.next; p=null;//刪除p size--; } return deleteNodeData; } //數(shù)組下標(biāo)是否越界 private Boolean isElementIndex(int index){ return index>=0&&index<size; } //插入位置是否越界 public Boolean isPositionIndex(int index){ return index>=0&&index<=size; } //檢驗(yàn)下標(biāo)是否越界,拋出異常 private void checkElementIndex(int index){ if(!isElementIndex(index)){ try { throw new IndexOutOfBoundsException("下標(biāo)越界"); } catch (Exception e) { e.printStackTrace(); } } } //檢驗(yàn)插入下標(biāo)是否越界,拋出異常 private void checkPositionIndex(int index){ if(!isPositionIndex(index)){ try { throw new IndexOutOfBoundsException("下標(biāo)越界"); } catch (Exception e) { e.printStackTrace(); } } } //返回指定位置的元素 private Node node(int index){ int nowIndex = 0; if(size>0){ for (Node p=head;p!=null;){ if (nowIndex==index){ return p; } p=p.next; nowIndex++; } } return null; } public static void main(String[] args) { java.util.LinkedList linkedList0=new java.util.LinkedList(); linkedList0.add(6); linkedList0.remove(0); linkedList0.size(); linkedList0.peek(); //linkedList0.getFirst(); linkedList0.clear(); //測(cè)試 LinkedList linkedList=new LinkedList(); linkedList.add(2); linkedList.add(6); linkedList.add(0); linkedList.add(3); linkedList.add(8); linkedList.add(10); System.out.println(linkedList.get(0)); System.out.println(linkedList.getFirst()); System.out.println(linkedList.getLast()); System.out.println(linkedList.get(5)); System.out.println(linkedList.remove(5)); System.out.println(linkedList.remove(4)); linkedList.remove(2); linkedList.remove(0); linkedList.remove(0); linkedList.remove(0); linkedList.add(2); linkedList.add(6); linkedList.add(0); linkedList.add(3); linkedList.add(8); linkedList.add(10); linkedList.removeFirst(); linkedList.removeFirst(); linkedList.removeLast(); System.out.println(linkedList.size()); System.out.println("遍歷鏈表"); linkedList.traverseList(); linkedList.add(0,4); linkedList.add(0,5); linkedList.add(2,5); linkedList.add(4,5); linkedList.add(6,9); linkedList.add(8,11); linkedList.add(9,222); // linkedList.linkBefore(3,new Node(3,null)); // linkedList.linkBefore(3,new Node(2,null)); // linkedList.linkBefore(3,new Node(2,null)); // linkedList.linkBefore(7,new Node(2,null)); // linkedList.linkBefore(9,new Node(7,null)); // linkedList.linkBefore(9,new Node(8,null)); System.out.println("遍歷鏈表"); linkedList.traverseList(); linkedList.clearList(); } }
以上就是Java簡(jiǎn)單實(shí)現(xiàn)線性表的鏈?zhǔn)酱鎯?chǔ),更多功能可參考Java集合中的LinkedList實(shí)現(xiàn)。
- java實(shí)現(xiàn)線性表及其算法
- java 線性表接口的實(shí)例詳解
- java線性表的存儲(chǔ)結(jié)構(gòu)及其代碼實(shí)現(xiàn)
- Java數(shù)據(jù)結(jié)構(gòu)順序表從零基礎(chǔ)到精通進(jìn)階
- Java?精煉解讀數(shù)據(jù)結(jié)構(gòu)的順序表如何操作
- Java實(shí)現(xiàn)順序表和鏈表結(jié)構(gòu)
- Java實(shí)現(xiàn)順序表的操作
- Java數(shù)據(jù)結(jié)構(gòu)之順序表篇
- Java中ArrayList與順序表的概念與使用實(shí)例
- Java線性表的順序表示及實(shí)現(xiàn)
相關(guān)文章
Java中的synchronized和ReentrantLock的區(qū)別詳細(xì)解讀
這篇文章主要介紹了Java中的synchronized和ReentrantLock的區(qū)別詳細(xì)解讀,synchronized是Java內(nèi)建的同步機(jī)制,所以也有人稱其為 IntrinsicLocking,它提供了互斥的語(yǔ)義和可見性,當(dāng)一個(gè)線程已經(jīng)獲取當(dāng)前鎖時(shí),其他試圖獲取的線程只能等待或者阻塞在那里,需要的朋友可以參考下2024-01-0130w+數(shù)據(jù)使用RedisTemplate?pipeline空指針NullPointerException異常分析
這篇文章主要為大家介紹了30w+數(shù)據(jù)使用RedisTemplate?pipeline空指針NullPointerException異常分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08java統(tǒng)計(jì)字符串單詞個(gè)數(shù)的方法解析
在一些項(xiàng)目中可能需要對(duì)一段字符串中的單詞進(jìn)行統(tǒng)計(jì),本文在這里分享了一個(gè)簡(jiǎn)單的demo,有需要的朋友可以拿去看一下2017-01-01Java基礎(chǔ)知識(shí)精通注釋與數(shù)據(jù)類型及常量與變量
本文給大家介紹了Java的注釋與數(shù)據(jù)類型和常量變量,這些都是最基礎(chǔ)的知識(shí),文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-04-04Spring Boot高級(jí)教程之使用Redis實(shí)現(xiàn)session共享
這篇文章主要為大家詳細(xì)介紹了Spring Boot高級(jí)教程之使用Redis實(shí)現(xiàn)session共享,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10基于MybatisPlus插件TenantLineInnerInterceptor實(shí)現(xiàn)多租戶功能
這篇文章主要介紹了基于MybatisPlus插件TenantLineInnerInterceptor實(shí)現(xiàn)多租戶功能,需要的朋友可以參考下2021-11-11javaweb用戶注銷后點(diǎn)擊瀏覽器返回刷新頁(yè)面重復(fù)登錄問題的解決方法
這篇文章主要為大家詳細(xì)介紹了javaweb用戶注銷后點(diǎn)擊瀏覽器返回刷新頁(yè)面重復(fù)登錄問題的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09