国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Josephus環類問題,java實現

2019-11-14 15:10:08
字體:
來源:轉載
供稿:網友

  寫出一個雙向的循環鏈表,弄一個計數器,我定義的是到三的時候,自動刪除當前節點,很簡單。

  

package Com;import java.util.Scanner;/* * 約瑟夫環問題,有n個人組成的圈,數到3的那個人出列,下個人繼續從一開始 */public class Josephus {        public static void main(String[] args) {        Scanner s = new Scanner(System.in);        int n = Integer.parseInt(s.nextLine());        Node first = new Josephus().startRun(n );        int count = 1;        while(first.next != first) {            first = first.next;            count++;            if(count == 3) {                first.PRevious.next = first.next;                first.next.previous = first.previous;                first = first.next;                count = 1;            }        }        System.out.println("最后剩下來的數字為:"+first.n);    }        public Node startRun(int n) {        Node first = new Node();        first.previous = null;        first.n = n ;   //這里給鏈表賦值,倒敘        Node current = first;        Node last = first;        while((--n)>0) {            current.next = new Node();            current = current.next;            current.n = n;            current.previous = last;            last = current;        }        current.next = first;        first.previous = current;        return first;    }    class Node {        int n ;         Node next;        Node previous;    }}

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 安阳县| 崇文区| 永福县| 南京市| 库尔勒市| 武功县| 沙湾县| 涞水县| 昭通市| 武隆县| 乌拉特前旗| 永平县| 大方县| 易门县| 西乌| 东台市| 霍州市| 二连浩特市| 武平县| 旌德县| 凌源市| 贡觉县| 安丘市| 丰镇市| 双峰县| 高清| 张家港市| 香格里拉县| 河池市| 读书| 长武县| 那曲县| 淮南市| 南岸区| 巢湖市| 通河县| 合水县| 延津县| 遵义县| 南投县| 林芝县|