亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

Java解決約瑟夫問題代碼實例

2019-11-26 15:35:33
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:
package list;

import java.util.ArrayList;


/**
 * Java約瑟夫問題: n個人(不同id)圍成一個圈,從startId(任意數)個開始報數m(任意數)個數,數m的人出列排成新隊列,m清零,
 * 然后又從下一個人開始數m個數開始,數到m就出列接在新隊列尾部,如此重復,知道所有人都出列為止。
 * 打印 出列后的新隊列
 *
 * eg
 * int n = 10;//總人數
 * int m = 3;   //報數個數
 * int startIndex = 1;  //起點位置
 * @author Hulk   2014  03 20
 *
 */
public class JosephListTest {
    public static void main(String[] args) {
        long startTime = System.currentTimeMillis();
        JosephListTest test = new JosephListTest();
        int n = 10; //總人數
        int m = 3; //報數個數
        int startIndex = 12; //起點位置
        System.out.println("JosephListTest: n= " + n + ", m= " + m +
            ", startIndex= " + startIndex + "/n/nQUEUE RESULT:");

        ArrayList<Person> queueList = test.queuePreson(n, m, startIndex);

        for (Person person : queueList) {
            System.out.println("OUT person: " + person);
        }

        System.out.println("use time= " +
            (System.currentTimeMillis() - startTime));
    }

    private ArrayList<Person> queuePreson(int n, int m, int startIndex) {
        ArrayList<Person> queueList = null;
        PersonList list = createList(n);

        //list.search();
        if ((list != null) && (list.head != null)) {
            queueList = new ArrayList<JosephListTest.Person>();

            PNode pNode = list.head;

            if (startIndex > 0) {
                startIndex = startIndex % n;
                pNode = list.getNode(startIndex);
            } else {
                pNode = list.head;
            }

            int count = 1;

            while (list.size > 0) {
                Person outPerson = null;

                //find
                if (count == (m - 1)) {
                    //delete next node
                    Person prev = pNode.person;
                    outPerson = list.remove(prev);
                    queueList.add(outPerson);
                    //System.out.println("OUT person: " + outPerson + ", size= " + list.size);
                    count = 0;
                }

                pNode = pNode.next;
                count++;
            }
        }

        return queueList;
    }

    private PersonList createList(int n) {
        PersonList list = new PersonList();

        for (int i = 0; i < n; i++) {
            Person person = new Person(i, "name_" + (i + 1));
            list.add(i, person);
        }

        return list;
    }

    public class PersonList {
        PNode head = null;
        int size = 0;

        public PersonList() {
        }

        public PersonList(Person person) {
            head = new PNode(person, head);
            size++;
        }

        public PersonList(PNode head) {
            this.head = head;
            head.setNext(head);
            size++;
        }

        public PNode getHead() {
            return head;
        }

        public void setHead(PNode head) {
            this.head = head;
        }

        public int getSize() {
            return size;
        }

        public void setSize(int size) {
            this.size = size;
        }

        public void size(int size) {
            this.size = size;
        }

        public boolean isEmpty() {
            return this.size <= 0;
        }

        public void initHead(Person person) {
            if (size == 0) {
                head = new PNode(person, head);
            } else {
                PNode no = head;
                head = new PNode(person, no);
            }

            size++;
        }

        public void add(int index, Person person) {
            if (size == 0) {
                head = new PNode(person, head);
                head.setNext(head);

                //System.out.println("head: " + head);
            } else {
                if (index < 0) {
                    index = 0;
                }

                if (index > size) {
                    index = size;
                }

                PNode no = head;

                for (int i = 0; i < (index - 1); i++) {
                    no = no.next;
                }

                PNode newNode = new PNode(person, no.next);
                no.next = newNode;
            }

            size++;
        }

        public Person delete(int index) {
            PNode pNode = remove(index);

            if ((pNode != null) && (pNode.next != null)) {
                return pNode.next.person;
            }

            return null;
        }

        public PNode remove(int index) {
            if (size == 0) {
                return null;
            } else {
                if ((index < 0) || (index >= size)) {
                    return null;
                }
            }

            PNode no = head;

            for (int i = 0; i < (index - 1); i++) {
                no = no.next;
            }

            no.next = no.next.next;
            size--;

            if ((no != null) && (no.next != null)) {
                return no.next;
            }

            return null;
        }

        /**
        * remove next node of person node, and return the deleted person
        * @param prePerson
        * @return  removed Person
        */
        public Person remove(Person prePerson) {
            if (prePerson == null) {
                return null;
            }

            if (size == 0) {
                return null;
            }

            PNode preNode = head;
            int index = -1;

            for (int i = 0; i < size; i++) {
                if (preNode.person.id == prePerson.id) {
                    index = i;

                    break;
                } else {
                    preNode = preNode.next;
                }
            }

            Person remPerson = null;

            if (size <= 1) {
                //only one node, get its person and set it as null
                remPerson = preNode.person;
                preNode = null;
            } else {
                //preNode.next.person is dest one
                remPerson = preNode.next.person;
                preNode.next = preNode.next.next;
            }

            size--;

            //System.out.println("deleteing index= " + index + " :  " + remPerson + ", size= " + size);
            return remPerson;
        }

        public int update(Person src, Person dest) {
            if (src == null) {
                return -1;
            }

            int index = -1;
            PNode no = head;

            for (int i = 0; i < size; i++) {
                if (src.id == no.person.id) {
                    no.person = dest;

                    break;
                } else {
                    no = no.next;
                }
            }

            return index;
        }

        public boolean set(int index, Person person) {
            if (person == null) {
                return false;
            }

            if (size == 0) {
                return false;
            } else {
                if ((index < 0) || (index >= size)) {
                    return false;
                }
            }

            PNode no = head;

            for (int i = 0; i < index; i++) {
                no = no.next;
            }

            no.person = person;

            return true;
        }

        public Person get(int index) {
            PNode no = getNode(index);

            if (no != null) {
                return no.person;
            }

            return null;
        }

        public PNode getNode(int index) {
            if (size == 0) {
                return null;
            } else {
                if ((index < 0) || (index >= size)) {
                    return null;
                }
            }

            PNode no = head;

            for (int i = 0; i < index; i++) {
                no = no.next;
            }

            return no;
        }

        public void search() {
            int sizeLong = size;
            PNode no = head;

            for (int i = 0; i < sizeLong; i++) {
                System.out.println("search index= " + i + ",   " + no);
                no = no.next;
            }
        }
    }

    public class PNode {
        Person person;
        PNode next = null;

        public PNode() {
        }

        public PNode(Person person) {
            this.person = person;
        }

        public PNode(Person person, PNode next) {
            this.person = person;
            this.next = next;
        }

        @Override
        public String toString() {
            return "PNode [person=" + person.id + ", next=" + next.person.id +
            "]";
        }

        public Person getPerson() {
            return person;
        }

        public void setPerson(Person person) {
            this.person = person;
        }

        public PNode getNext() {
            return next;
        }

        public void setNext(PNode next) {
            this.next = next;
        }
    }

    public class Person {
        int id = 0;
        String name = "";

        public Person() {
        }

        public Person(int id, String name) {
            super();
            this.id = id;
            this.name = name;
        }

        @Override
        public String toString() {
            return "Person [id=" + id + ", name=" + name + "]";
        }
    }
}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美激情视频网| 亚洲福利视频网| 精品福利樱桃av导航| 午夜免费日韩视频| 国产日韩欧美视频在线| 91精品美女在线| 亚洲国产成人精品久久久国产成人一区| 91成人精品网站| 一区二区三区亚洲| 亚洲欧美另类中文字幕| 亚洲韩国青草视频| 精品久久久国产精品999| 成人免费网站在线观看| 亚洲最大福利网站| 成人国产精品久久久久久亚洲| 欧美色xxxx| 欧美日韩国产123| 91国内揄拍国内精品对白| 欧美成人黄色小视频| 日韩免费在线视频| 久久久精品欧美| 欧美色欧美亚洲高清在线视频| 日韩中文字幕亚洲| 中文字幕av一区中文字幕天堂| 欧美日韩在线第一页| 久久久久久久久综合| 超在线视频97| 永久免费看mv网站入口亚洲| 久久精品男人天堂| 这里只有精品在线播放| 欧美黑人一级爽快片淫片高清| 日韩精品视频免费在线观看| 久久视频国产精品免费视频在线| 国产v综合v亚洲欧美久久| 国产精品久久久久久久久借妻| 欧洲美女7788成人免费视频| 在线播放国产精品| 亚洲人成伊人成综合网久久久| 亚洲小视频在线| 日韩av影视在线| 日韩经典中文字幕| 国产精品27p| 亚洲精品国产精品国自产观看浪潮| 午夜精品久久久久久久99热| 国产精品久久av| 亚洲自拍欧美色图| 亚洲经典中文字幕| 亚洲跨种族黑人xxx| 亚洲成人黄色在线| 亚洲欧洲在线播放| 欧美性猛交xxxxx水多| 久久99久久99精品中文字幕| 国产一区二区三区在线播放免费观看| 亚洲无线码在线一区观看| 国产一区玩具在线观看| 久久91精品国产91久久久| 久久久99久久精品女同性| 日韩免费黄色av| 欧美激情久久久久久| 久久婷婷国产麻豆91天堂| 色婷婷综合久久久久中文字幕1| 欧美国产日韩在线| 成人黄色免费片| 欧美成人免费观看| 久久成人精品视频| 亚洲free嫩bbb| 性欧美视频videos6一9| 国产精品免费电影| 91精品在线国产| 亚洲视频欧美视频| 国产丝袜视频一区| 国产精品久久久久久久久免费看| 一本一本久久a久久精品综合小说| 久久精品国亚洲| 欧美日韩中文在线观看| 国产精品白丝jk喷水视频一区| 欧美精品18videosex性欧美| 欧美激情精品久久久久久黑人| 欧美激情第99页| 动漫精品一区二区| 亚洲欧美日韩在线高清直播| 在线激情影院一区| 久久国产精品偷| 久久九九亚洲综合| 中文字幕日韩在线视频| 欧美午夜宅男影院在线观看| 国产精品久久久久久久久久久不卡| 久久在精品线影院精品国产| 国产欧美精品va在线观看| 国产精品你懂得| 欧美最猛性xxxxx(亚洲精品)| 亚洲人成电影在线播放| 精品久久国产精品| 国产精品h片在线播放| 亚洲直播在线一区| 2019国产精品自在线拍国产不卡| 久久躁日日躁aaaaxxxx| 欧美激情乱人伦一区| 亚洲社区在线观看| 亚洲大尺度美女在线| 国内揄拍国内精品少妇国语| 欧美精品免费看| 日韩中文字幕免费看| 亚洲欧美另类在线观看| 亚洲精品99999| 中文字幕在线观看日韩| 中文字幕日韩欧美精品在线观看| 成人av电影天堂| 欧美性色xo影院| 久久综合九色九九| 日韩美女av在线免费观看| 色婷婷av一区二区三区在线观看| 成人性生交xxxxx网站| 久久电影一区二区| 国产精品xxxxx| 亚洲欧美激情在线视频| 久久中文字幕在线| 欧美性xxxx极品hd满灌| 中文字幕亚洲欧美日韩高清| 国产精品一区二区女厕厕| 亚洲美女激情视频| 欧美性猛交99久久久久99按摩| 中文字幕日韩精品有码视频| 日韩av黄色在线观看| 欧美精品在线视频观看| 日韩精品在线电影| 在线看日韩av| 亚洲欧美在线一区| 成人精品一区二区三区电影免费| 亚洲国产成人在线播放| 国产精品高潮呻吟视频| 成人国产精品久久久久久亚洲| 日韩有码在线播放| 国产日韩中文字幕在线| 亚洲成人激情在线观看| 97在线免费观看视频| 97精品国产97久久久久久免费| 国产亚洲欧美日韩精品| 久久久久久久久爱| 日韩精品亚洲精品| 欧美极品美女视频网站在线观看免费| 欧美在线视频一二三| 欧美激情日韩图片| 欧美日韩亚洲国产一区| 亚洲国产另类 国产精品国产免费| 国产视频久久久| 久久精品国产亚洲精品2020| 欧美极品美女视频网站在线观看免费| 国产手机视频精品| 日韩激情片免费| 亚洲色图av在线| …久久精品99久久香蕉国产| 国产精品视频资源| 国内精久久久久久久久久人| 色综合久久久久久中文网| 这里精品视频免费| 国产精品高精视频免费| 91精品国产自产在线观看永久| 国产精品69av| 国产日韩欧美在线| 亚洲欧洲在线视频| 日韩美女在线播放| 日韩av中文在线| 久久久久久成人精品|