Java實(shí)現(xiàn)帶頭結(jié)點(diǎn)的單鏈表

鏈表的特點(diǎn)

張家川回族自治網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),張家川回族自治網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為張家川回族自治上千余家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)要多少錢,請找那個售后服務(wù)好的張家川回族自治做網(wǎng)站的公司定做!

1,以節(jié)點(diǎn)方式存儲,是鏈?zhǔn)浇Y(jié)構(gòu)。

2,每個節(jié)點(diǎn)包含data域,next域:指向下一個節(jié)點(diǎn)。

3,鏈表的各個節(jié)點(diǎn)不一定是連續(xù)存儲。

4,鏈表分為帶頭節(jié)點(diǎn)和不帶頭節(jié)點(diǎn)兩種類型的鏈表。

實(shí)現(xiàn)原理

添加節(jié)點(diǎn):如下圖所示,首先遍歷原有鏈表,找到最后一個節(jié)點(diǎn),將要增加的節(jié)點(diǎn)添加到該節(jié)點(diǎn)的后面。下面介紹如何找到最后一個節(jié)點(diǎn)。

Java實(shí)現(xiàn)帶頭結(jié)點(diǎn)的單鏈表

思路是這樣的,先遍歷整個鏈表,定義一個輔助變量temp,用于暫時存儲遍歷出來的各個節(jié)點(diǎn)。首先將head頭節(jié)點(diǎn)賦給temp(從頭節(jié)點(diǎn)開始遍歷),通過一個死循環(huán)不斷的遍歷節(jié)點(diǎn)的next,直到temp.next==null時,該節(jié)點(diǎn)temp就是鏈表的最后一個節(jié)點(diǎn),只需要將該節(jié)點(diǎn)的next指向新增節(jié)點(diǎn)就行了。

修改節(jié)點(diǎn):首先遍歷整個鏈表,通過傳入的編號去匹配原有的鏈表的編號,找到對應(yīng)的編號將節(jié)點(diǎn)里面的數(shù)據(jù)替換即可。

刪除節(jié)點(diǎn):如圖所示,要刪除某一節(jié)點(diǎn),需要遍歷整個鏈表,找到該節(jié)點(diǎn)對應(yīng)的編號,再將該前一個節(jié)點(diǎn)的next指向要刪除的節(jié)點(diǎn)的后面的一個節(jié)點(diǎn),即(temp.next = temp.next.next)。由于被刪除的節(jié)點(diǎn)沒有被引用,將會被垃圾回收機(jī)制回收掉。

Java實(shí)現(xiàn)帶頭結(jié)點(diǎn)的單鏈表

主要代碼

package cn.mrlij.linkedlist;
/***
 * 單鏈表的實(shí)現(xiàn)
 * @author dreamer
 *
 */
public class SingleLinkedList {
 public static void main(String[] args) {
 SingleLinkedListDemo s = new SingleLinkedListDemo();
 HeroNode h2 = new HeroNode(1, "宋江", "及時雨");
 HeroNode h3 = new HeroNode(3, "盧俊義", "玉麒麟");
 HeroNode h4 = new HeroNode(4, "吳用", "智多星");
 HeroNode h5 = new HeroNode(2, "林沖", "豹子頭");
 s.addByOrder(h2);
 s.addByOrder(h3);
 s.addByOrder(h4);
 s.addByOrder(h5);
 System.out.println("修改前————");
 s.list();
// HeroNode h6 = new HeroNode(4, "有用", "超星星");
// s.update(h6);
 s.del(1);
 s.del(4);
 s.del(2);
 s.del(3);
 System.out.println("刪除后————");
 s.list();
 }
 
}
class SingleLinkedListDemo{
 //創(chuàng)建一個頭結(jié)點(diǎn),初始化數(shù)據(jù),頭結(jié)點(diǎn)不要動,不放具體的數(shù)據(jù)
 private HeroNode head = new HeroNode(0,"","");
 //添加英雄
 public void add(HeroNode node) {
 //先找出最后的一個節(jié)點(diǎn),把新加的節(jié)點(diǎn)放在最后一個節(jié)點(diǎn)的后面
 HeroNode temp = head;
 while(true) {
  if(temp.next == null) {
  break;
  }
  temp = temp.next;
 }
 temp.next = node;
 }
 public void addByOrder(HeroNode node) {
 HeroNode temp = head;
 boolean flag = false;
 while(true) {
  if(temp.next == null) {
  break;
  }
  if(temp.next.no>node.no) {
  break;
  }else if(temp.next.no == node.no) {
  flag = true;
  break;
  }
  temp = temp.next;
 }
 if(flag) {
  System.out.println("編號"+node.no+"已經(jīng)存在了!");
 }else {
  node.next = temp.next;
  temp.next = node;
 }
 }
 public void update(HeroNode node ) {
 if(head.next == null) {
  System.out.println("鏈表為空!");
  return;
 }
 HeroNode temp = head.next;
 boolean flag = false;
 while(true) {
  if(temp == null) {
  break;
  }
  if(temp.no == node.no) {
  flag = true;
  break;
  }
  temp = temp.next;
 }
 if(flag) {
  temp.name = node.name;
  temp.nickname = node.name;
 }else {
  System.out.println("不存在該節(jié)點(diǎn)!");
 }
 }
 //刪除節(jié)點(diǎn)
 public void del(int no) {
 if(head.next == null) {
  System.out.println("鏈表為空!");
  return;
 }
 HeroNode temp = head;
 boolean flag = false;
 while(true) {
  if(temp.next == null) {
  break;
  }
  if(temp.next.no == no) {
  flag = true;
  break;
  }
  temp = temp.next;
 }
 if(flag) {
  temp.next = temp.next.next;
 }else {
  System.out.println("該節(jié)點(diǎn)不存在!");
 }
 }
 public void list() {
 HeroNode temp = head;
 if(temp.next == null) {
  System.out.println("鏈表為空!");
  return;
 }
 while(true) {
  if(temp.next == null) {
  break;
  }
  System.out.println(temp.next);
  temp = temp.next; 
 }
 }
}
class HeroNode{
 public int no;//英雄編號
 public String name;//人名
 public String nickname;//綽號
 public HeroNode next;//下一個節(jié)點(diǎn)
 public HeroNode(int no, String name, String nickname) {
 this.no = no;
 this.name = name;
 this.nickname = nickname;
 }
 @Override
 public String toString() {
 return "HeroNode [no=" + no + ", name=" + name + ", nickname=" + nickname + "]";
 }
 
 
 
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

網(wǎng)站題目:Java實(shí)現(xiàn)帶頭結(jié)點(diǎn)的單鏈表
網(wǎng)頁路徑:http://bm7419.com/article34/pscpse.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、響應(yīng)式網(wǎng)站、網(wǎng)站導(dǎo)航商城網(wǎng)站、Google、網(wǎng)頁設(shè)計(jì)公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)