Java之單鏈表問題解決案例講解
單鏈表
單鏈表是一種鏈式存取的數(shù)據(jù)結(jié)構(gòu),用一組地址任意的存儲單元存放線性表中的數(shù)據(jù)元素。
鏈表中的數(shù)據(jù)是以結(jié)點來表示的,每個結(jié)點的構(gòu)成:元素(數(shù)據(jù)元素的映象) + 指針(指示后繼元素存儲位置),元素就是存儲數(shù)據(jù)的存儲單元,指針就是連接每個結(jié)點的地址數(shù)據(jù)。
問題
問題1:給定一個單鏈表,判斷鏈表中是否有環(huán)
問題2:給定一個鏈表,返回鏈表開始入環(huán)的第一個節(jié)點,如果無環(huán),則返回null
class Node{ public int data; Node next; public Node(int data){ this.data=data; this.next=null; } } public class linkedList { /*給定一個鏈表,判斷鏈表中是否有環(huán) 思路: 如果鏈表有環(huán)的話,定義兩個節(jié)點fast,slow。讓fast一次走兩步,slow一次走一步; 如果能相交,即fast=slow,說明有交點,且如果有環(huán),節(jié)點的next也不會為空 */ public Node head; public boolean hasCycle(){ Node fast=this.head; Node slow=this.head; while (fast!=null&&fast.next!=null){//如果把fast.next寫下前面,一旦fast為空,則會空指針異常 fast=fast.next.next; slow=slow.next; if(fast==slow){ return true; } } return false; } //給定一個鏈表,返回鏈表開始入環(huán)的第一個節(jié)點,如果無環(huán),則返回null public Node detectCycle(){ /*定義fast與slow,fast前進2格,slow前進一格,如果有交點的話,fast與slow第一次相遇時,fast的路程為slow的2倍, 如設(shè)從頭節(jié)點到入環(huán)節(jié)點的距離為X,令入環(huán)節(jié)點到fast,slow第一次相遇距離為Y,環(huán)的總長度為C的話;可得公式:2(X+Y)=X+Y+NC; 得X=NC-Y,令N等于1,X=C-Y;此時讓slow從頭節(jié)點開始走,當(dāng)于速度相同的fast相遇時,則為入環(huán)的節(jié)點。 */ Node fast=this.head; Node slow=this.head; while (fast!=null&&fast.next!=null){ fast=fast.next.next; slow=slow.next; if(fast==slow){//第一次相遇 break; } } if(fast==null&&fast.next==null){ return null; } //此時讓slow從頭節(jié)點開始,與fast以相同速度前進,遇到則為入環(huán)的第一個節(jié)點 slow=this.head; while (fast!=slow){ fast=fast.next; slow=slow.next; } return slow; } }
到此這篇關(guān)于Java之單鏈表問題解決案例講解的文章就介紹到這了,更多相關(guān)Java之單鏈表問題內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java并發(fā) synchronized鎖住的內(nèi)容解析
這篇文章主要介紹了Java并發(fā) synchronized鎖住的內(nèi)容解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-09-09SpringMVC整合SpringSession 實現(xiàn)sessiong
這篇文章主要介紹了SpringMVC整合SpringSession 實現(xiàn)session的實例代碼,本文通過實例相結(jié)合的形式給大家介紹的非常詳細,需要的朋友參考下吧2018-04-04Spring Boot 項目設(shè)置網(wǎng)站圖標的方法
這篇文章主要介紹了Spring Boot 項目設(shè)置網(wǎng)站圖標的方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2020-02-02springboot2.6.7集成springfox3.0.0的示例代碼
這篇文章主要介紹了springboot2.6.7集成springfox3.0.0的示例代碼,本文通過示例代碼給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧2024-04-04@Transactional跟@DS動態(tài)數(shù)據(jù)源注解沖突的解決
這篇文章主要介紹了@Transactional跟@DS動態(tài)數(shù)據(jù)源注解沖突的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09