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)文章
MybatisPlus調(diào)用原生SQL的實現(xiàn)方法
本文主要介紹了MybatisPlus調(diào)用原生SQL的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02
線程局部變量的實現(xiàn)?ThreadLocal使用及場景介紹
這篇文章主要為大家介紹了線程局部變量的實現(xiàn)?ThreadLocal使用及場景詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01
Java的MyBatis框架中MyBatis Generator代碼生成器的用法
這篇文章主要介紹了Java的MyBatis框架中Mybatis Generator代碼生成器的用法,Mybatis Generator主要被用來生成繁瑣的配置文件來提高效率,需要的朋友可以參考下2016-04-04
springMVC利用FastJson接口返回json數(shù)據(jù)相關(guān)配置詳解
本篇文章主要介紹了springMVC利用FastJson接口返回json數(shù)據(jù)相關(guān)配置詳解,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06
使用ServletUtil.write方法下載接口文件中文亂碼問題解決
本文主要介紹了使用ServletUtil.write方法下載接口文件中文亂碼問題解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-05-05
java管道piped輸入流與輸出流應(yīng)用場景案例分析
這篇文章主要介紹了java管道流PipedInputStream與PipedOutputStream(輸入流與輸出流)的應(yīng)用場景案例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步2022-02-02
Java事務(wù)管理學(xué)習(xí)之JDBC詳解
這篇文章主要介紹了Java事務(wù)管理學(xué)習(xí)之JDBC的相關(guān)資料,文中介紹的非常詳細,相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。2017-03-03

