欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java基于雙向環(huán)形鏈表解決丟手帕問題的方法示例

 更新時間:2017年11月07日 12:21:14   作者:逐兔郎  
這篇文章主要介紹了java基于雙向環(huán)形鏈表解決丟手帕問題的方法,簡單描述了丟手帕問題,并結(jié)合實(shí)例形式給出了Java基于雙向環(huán)形鏈表解決丟手帕問題的步驟與相關(guān)操作技巧,需要的朋友可以參考下

本文實(shí)例講述了java基于雙向環(huán)形鏈表解決丟手帕問題的方法。分享給大家供大家參考,具體如下:

問題:設(shè)編號為1、2……n的幾個小孩圍坐一圈,約定編號為k(1=<k<=n)的小孩從1開始報數(shù),數(shù)到m的那個出列,他的下一位又從1開始報數(shù),數(shù)到m的那個人又出列,直到所有人出列為止,由此產(chǎn)生一個出隊(duì)編號的序列。

我們現(xiàn)在用一個雙向環(huán)形鏈表來解這一問題。先來看看下面這幅圖:

圓圈代表一個結(jié)點(diǎn),紅色的指針指向下一個元素,紫色的指針指向上一個元素。first指針指向第一個元素,表明第一個元素的位置,cursor是游標(biāo)指針,它的作用重大。那么這個環(huán)形的鏈表就可以模擬小孩排成的圓圈,下面是具體的代碼:

public class Test {
  public static void main(String[] args){
      CycleLink cl=new CycleLink(5); //構(gòu)造環(huán)形鏈表
      System.out.println("腳本之家測試結(jié)果:");
      cl.print();
      cl.setK(2); //設(shè)置從第幾個小孩開始數(shù)數(shù)
      cl.setM(3); //設(shè)置數(shù)幾下
      cl.play(); //開始游戲
  }
}
class Child{
  int no;
  Child nextChild;
  Child previousChild;
  public Child(int no){
    this.no=no;
  }
}
class CycleLink{
  Child first;
  Child cursor;
  int length;
  //從第幾個小孩開始數(shù)
  private int k=1;
  //數(shù)幾下
  private int m=1;
  //構(gòu)造函數(shù)
  public CycleLink(int len){
    this.length=len;
    for(int i=1;i<=length;i++){
      Child ch=new Child(i);
      if(i==1){
        first=ch;
        cursor=ch;
      }else if(i<length){
        cursor.nextChild=ch;
        ch.previousChild=cursor;
        cursor=ch;
      }else {
        cursor.nextChild=ch;
        ch.previousChild=cursor;
        cursor=ch;
        ch.nextChild=first;
        first.previousChild=ch;
      }
    }
  }
  //打印鏈表
  public void print(){
    cursor=first;
    do{
      System.out.print(cursor.no+"<<");
      cursor=cursor.nextChild;
    }while(cursor!=first);
    System.out.println();
  }
  //開始游戲
  public void play(){
    Child temp;
    cursor=first;
    //先找到第k個小孩
    while(cursor.no<k){
      cursor=cursor.nextChild;
    }
    while(length>1){
      //數(shù)m下
      for(int i=1;i<m;i++){
        cursor=cursor.nextChild;
      }
      System.out.println("小孩"+cursor.no+"出局了!");
      //找到前一個小孩
      temp=cursor.previousChild;
//     temp=cursor;
//     do{
//       temp=temp.nextChild;
//     }while(temp.nextChild!=cursor);
      temp.nextChild=cursor.nextChild;
      cursor.nextChild.previousChild=temp;
      cursor=cursor.nextChild;
      length--;
    }
    System.out.println("最后一個出局的小孩是"+cursor.no);
  }
  public void setK(int k) {
    this.k = k;
  }
  public void setM(int m) {
    this.m = m;
  }
}

這個代碼的基本框架是根據(jù)韓順平的視頻的。不過他用的是一個單向的鏈表,上面的代碼注釋的部分是用來找cursor所指向的元素的上一個元素的,是將整個鏈表轉(zhuǎn)了一圈來實(shí)現(xiàn)的。這里我改成了雙向鏈表,直接用一個cursor.previousChild就可以了。

運(yùn)行結(jié)果:

更多關(guān)于java算法相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總

希望本文所述對大家java程序設(shè)計有所幫助。

相關(guān)文章

  • SpringBoot中的靜態(tài)資源訪問的實(shí)現(xiàn)

    SpringBoot中的靜態(tài)資源訪問的實(shí)現(xiàn)

    這篇文章主要介紹了SpringBoot中的靜態(tài)資源訪問的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • java連接sql server 2008數(shù)據(jù)庫代碼

    java連接sql server 2008數(shù)據(jù)庫代碼

    Java的學(xué)習(xí),很重要的一點(diǎn)是對數(shù)據(jù)庫進(jìn)行操作。
    2013-03-03
  • Java單表實(shí)現(xiàn)評論回復(fù)功能(多種實(shí)現(xiàn)方式)

    Java單表實(shí)現(xiàn)評論回復(fù)功能(多種實(shí)現(xiàn)方式)

    這篇文章主要介紹了Java單表實(shí)現(xiàn)評論回復(fù)功能,大家都知道評論功能有多種實(shí)現(xiàn)方式,本文逐一給大家詳細(xì)講解,需要的朋友可以參考下
    2023-03-03
  • @Value注入List、數(shù)組、Set、Map問題

    @Value注入List、數(shù)組、Set、Map問題

    這篇文章主要介紹了@Value注入List、數(shù)組、Set、Map問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • java實(shí)現(xiàn)發(fā)送email小案例

    java實(shí)現(xiàn)發(fā)送email小案例

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)發(fā)送email小案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • MyEclipse10安裝Log4E插件

    MyEclipse10安裝Log4E插件

    這篇文章主要介紹了MyEclipse10安裝Log4E插件的相關(guān)資料,需要的朋友可以參考下
    2017-10-10
  • jmeter基本使用小結(jié)

    jmeter基本使用小結(jié)

    jmeter是apache公司基于java開發(fā)的一款開源壓力測試工具,體積小,功能全,使用方便,是一個比較輕量級的測試工具,使用起來非常簡單。本文就簡單的介紹一下如何使用,感興趣的
    2021-11-11
  • java正則替換sql中的參數(shù)實(shí)例代碼

    java正則替換sql中的參數(shù)實(shí)例代碼

    這篇文章主要給大家介紹了關(guān)于java正則替換sql中參數(shù)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2022-10-10
  • String的兩種初始化方法講解

    String的兩種初始化方法講解

    今天小編就為大家分享一篇關(guān)于String的兩種初始化方法講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-04-04
  • 教你代碼中獲取當(dāng)前?JAR?包的存放位置

    教你代碼中獲取當(dāng)前?JAR?包的存放位置

    這篇文章主要介紹了如何獲取當(dāng)前JAR包的存放位置,要獲取當(dāng)前運(yùn)行的 JAR 包所存放的位置,可以使用 ProtectionDomain 和 CodeSource 類,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-08-08

最新評論