日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Java實現線性表的鏈式存儲

瀏覽:60日期:2022-08-21 17:15:04

本文實例為大家分享了Java實現線性表的鏈式存儲,供大家參考,具體內容如下

鏈表:一種物理存儲結構上非連續、非順序的存儲結構,數據元素的邏輯順序是通過鏈表中的指針鏈接次序實現的。

package algorithm.datastructure.linklist;import java.util.NoSuchElementException;/** 鏈表* 物理存儲上非連續的存儲結構,數據元素的邏輯順序是通過鏈表中的指針鏈接次序實現* * */public class LinkedList { private Node head;//頭節點 private int size;//鏈表長度 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; } //在某個位置之前添加元素 public Boolean add(int index,Integer element){ checkPositionIndex(index); if (index==size){ linkLast(element); } else { linkBefore(element,node(index)); } return true; } //根據下標獲取元素 public int get(int index){ checkElementIndex(index); return node(index).data; } //獲取第一個元素 public Integer getFirst(){ Node f=head; if (f==null){ throw new NoSuchElementException(); } else { return f.data; } } //獲取最后一個元素 public Integer getLast(){ if (size==0){ throw new NoSuchElementException(); } int index=size-1; return node(index).data; } //刪除第一個元素 public Integer removeFirst(){ Node f=head; if (f==null){ throw new NoSuchElementException(); } else { return unlink(head); } } //刪除最后一個元素 public Integer removeLast(){ if (size==0){ throw new NoSuchElementException(); } int index=size-1; return unlink(node(index)); } //根據索引刪除元素 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;//記錄下一個結點 p=null;//刪除當前結點 p=next;//指向下一個結點 } size=0; head=null; } //遍歷鏈表 public void traverseList(){ for (Node p=head;p!=null;){ System.out.println(p.data); p=p.next; } } //返回鏈表元素個數 public int size(){ return size; } //尾部添加結點 private void linkLast(int element){ Node cur =null,p; if (size==0){//沒有結點時 head=new Node(element,null); size++; return; } for (p=head;p!=null;){//有結點時候 cur=p; p=cur.next; } cur.next= new Node(element,null);//尾部添加元素 size++; } //在某結點之前插入結點 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為結點時候 head= new Node(element, p);//在頭部插入元素 size++; } else { while (p!=null){ if (q.data==node.data) { p.next= new Node(element,q);//在q之前(p之后)插入一個元素 size++; break; } p=p.next; q=p.next; } } } } //刪除結點 private Integer unlink(Node node){ Integer deleteNodeData=null; Node p=null; deleteNodeData=node.data; if (node.data==head.data){//該節點為頭結點 p=head; head=p.next; p=null; size--; } else { Node q=head; for (p=q.next;p!=null;){//使用兩個指針,p,q if (p.data==node.data){ break; } q=q.next;//p始終為q的next結點 p=q.next; } q.next=p.next; p=null;//刪除p size--; } return deleteNodeData; } //數組下標是否越界 private Boolean isElementIndex(int index){ return index>=0&&index<size; } //插入位置是否越界 public Boolean isPositionIndex(int index){ return index>=0&&index<=size; } //檢驗下標是否越界,拋出異常 private void checkElementIndex(int index){ if(!isElementIndex(index)){ try { throw new IndexOutOfBoundsException('下標越界'); } catch (Exception e) { e.printStackTrace(); } } } //檢驗插入下標是否越界,拋出異常 private void checkPositionIndex(int index){ if(!isPositionIndex(index)){ try { throw new IndexOutOfBoundsException('下標越界'); } 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(); //測試 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簡單實現線性表的鏈式存儲,更多功能可參考Java集合中的LinkedList實現。

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
麻豆精品蜜桃| 国产精品国产三级国产在线观看| 99久久久国产精品美女| 亚洲成人二区| 欧美日韩精品一本二本三本 | 日本伊人午夜精品| 国产亚洲高清在线观看| 久久久久久亚洲精品美女| 中文在线а√天堂| 国产视频一区三区| 日韩激情av在线| 精品三级国产| 欧美理论视频| 亚洲乱亚洲高清| 日韩高清电影免费| 日本激情一区| 99日韩精品| 国产欧美日韩免费观看| 日韩成人免费| aⅴ色国产欧美| 欧美精品国产| 欧美gv在线| 免费人成精品欧美精品| 麻豆精品久久| 国产精品日本| 久久久久久亚洲精品美女| 亚洲香蕉网站| 日本欧美在线| 日本精品影院| 日韩不卡免费高清视频| 亚洲69av| 麻豆视频在线观看免费网站黄| 在线亚洲国产精品网站| 国产精品久一| 国产精品一区二区中文字幕| 久久精品91| 蜜桃一区二区三区在线观看| 精品欧美日韩精品| 视频在线观看国产精品| 久久婷婷国产| 中文日韩在线| 日产精品一区二区| 日本综合精品一区| 久久国产电影| 国产日韩欧美一区| 欧美美女一区| 国产不卡av一区二区| 亚洲精品高潮| 美女少妇全过程你懂的久久| 麻豆视频一区二区| 久久电影一区| 香蕉久久精品| 欧美激情另类| 国产精品美女午夜爽爽| 蜜臀av性久久久久蜜臀aⅴ四虎| 日韩电影免费网址| 国产精品久久久久久久久久久久久久久| 欧美在线影院| 成人片免费看| 欧美自拍一区| 亚洲三级av| 亚洲精品电影| 日韩一区二区三区在线免费观看| 国产精品亚洲综合久久| 亚洲精品日本| 欧美日韩视频| 香蕉成人av| 高清在线一区| 久久精品网址| 136国产福利精品导航网址| 国内不卡的一区二区三区中文字幕| 日韩区欧美区| 亚洲精品看片| 中文字幕乱码亚洲无线精品一区| 国产亚洲精aa在线看| 日本vs亚洲vs韩国一区三区二区| 欧洲激情综合| 久久国产电影| 激情丁香综合| 91精品二区| 国产精品av久久久久久麻豆网| 97精品国产| 国产专区精品| 日本久久黄色| 午夜欧美巨大性欧美巨大| 伊人久久av| 99久久精品费精品国产| 久久中文字幕av| 99久久精品网| 欧美日韩在线网站| 九九综合在线| 欧美a级片一区| 亚洲视频综合| 亚洲精品va| 亚洲欧美久久久| 日韩精品一二三| 亚洲精品高潮| 日韩精品导航| 国产日韩欧美一区| 久久久久伊人| 国产 日韩 欧美一区| 久久亚洲成人| 国产毛片一区| 日韩精品国产精品| 国产午夜精品一区在线观看| 国产精品欧美日韩一区| 欧美国产专区| 亚洲天堂1区| 狠狠干成人综合网| 亚洲欧美日本国产| 国产精品激情| 亚洲四虎影院| 爽好久久久欧美精品| 国产日韩亚洲欧美精品| 日韩成人精品一区| 欧美专区在线| 欧美三区不卡| www.九色在线| 亚洲一区二区三区四区五区午夜| 中文视频一区| 麻豆久久久久久久| 欧美日韩精品一区二区视频| 欧美中文日韩| 国产经典一区| 欧美freesex黑人又粗又大| 99国产精品久久久久久久| 日韩毛片网站| 中文字幕在线免费观看视频| 尤物精品在线| 国产日韩一区二区三区在线播放| sm捆绑调教国产免费网站在线观看| 欧美va天堂在线| 日韩福利视频导航| 色综合狠狠操| 亚洲欧美日韩国产一区二区| 欧美亚洲综合视频| 久久久9色精品国产一区二区三区| 午夜一区在线| 国产视频一区二区在线播放| 久久国产电影| 久久狠狠久久| 91精品电影| 免费在线日韩av| 黄色av日韩| 久久精品99国产国产精| 日韩精品首页| 久久激情五月婷婷| 亚洲不卡av不卡一区二区| 日韩激情精品| 亚洲天堂1区| 欧美久久亚洲| 日韩视频精品在线观看| 精品视频黄色| 亚洲三级视频| 亚洲午夜电影| 国产伊人久久| 中文字幕日韩亚洲| 精品三级久久| 国产精品手机在线播放| 久久影视一区| 国内精品麻豆美女在线播放视频| 午夜一级久久| 久久久人人人| 美女视频黄 久久| 中文字幕一区二区三区四区久久| 国产在线观看www| 国产精品一区二区免费福利视频| 亚洲激精日韩激精欧美精品| 日本久久黄色| 久久国产欧美日韩精品| 亚洲自啪免费| 久久国产亚洲精品| 欧美a在线观看| 日本中文字幕不卡| 黑丝一区二区| 久久中文视频| 成人福利视频| 美女视频黄免费的久久| 婷婷精品久久久久久久久久不卡| 久久视频精品| а√在线中文在线新版| 国产精品第一国产精品| 日本亚洲最大的色成网站www| 国产亚洲永久域名| 午夜电影亚洲| 欧美影院三区| 久久亚洲在线| 成人看片网站| 色偷偷色偷偷色偷偷在线视频| 国产日韩欧美高清免费| 亚洲精品乱码久久久久久蜜桃麻豆| 免费视频亚洲| 欧美.日韩.国产.一区.二区 | 日韩中文字幕一区二区高清99| 五月天久久久| 欧美日韩激情| 亚洲激情社区| 在线亚洲自拍| 99热精品在线| 视频一区二区中文字幕|