亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2020年11月25日 11:54:00   作者:dreamer_it  
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)帶頭結(jié)點(diǎn)的單鏈表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

鏈表的特點(diǎn)

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

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

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

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

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

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

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

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

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

主要代碼

package cn.mrlij.linkedlist;
/***
 * 單鏈表的實(shí)現(xiàn)
 * @author dreamer
 *
 */
public class SingleLinkedList {
 public static void main(String[] args) {
 SingleLinkedListDemo s = new SingleLinkedListDemo();
 HeroNode h1 = new HeroNode(1, "宋江", "及時(shí)雨");
 HeroNode h2 = new HeroNode(3, "盧俊義", "玉麒麟");
 HeroNode h3 = new HeroNode(4, "吳用", "智多星");
 HeroNode h4 = new HeroNode(2, "林沖", "豹子頭");
 s.addByOrder(h1);
 s.addByOrder(h2);
 s.addByOrder(h3);
 s.addByOrder(h4);
 System.out.println("修改前————");
 s.list();
// HeroNode h5 = new HeroNode(4, "有用", "超星星");
// s.update(h5);
 s.del(1);
 s.del(4);
 s.del(2);
 s.del(3);
 System.out.println("刪除后————");
 s.list();
 }
 
}
class SingleLinkedListDemo{
 //創(chuàng)建一個(gè)頭結(jié)點(diǎn),初始化數(shù)據(jù),頭結(jié)點(diǎn)不要?jiǎng)樱环啪唧w的數(shù)據(jù)
 private HeroNode head = new HeroNode(0,"","");
 //添加英雄
 public void add(HeroNode node) {
 //先找出最后的一個(gè)節(jié)點(diǎn),把新加的節(jié)點(diǎn)放在最后一個(gè)節(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("編號(hào)"+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;//英雄編號(hào)
 public String name;//人名
 public String nickname;//綽號(hào)
 public HeroNode next;//下一個(gè)節(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 + "]";
 }
 
 
 
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論