欢迎来到天天文库
浏览记录
ID:6471728
大小:44.50 KB
页数:4页
时间:2018-01-15
《java环形链表实现约瑟夫问题(丢手帕问题)》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、/***作者:徐守威*功能:约瑟夫问题(丢手帕问题)*具体问题:设编号为1,2,3....n的n个人围坐一圈,约定编号为k(1<=k<=n)的人从1开始*报数,数到m的那个人出列,它的下一位从一开始报数,报到m的那个人又出列,以此类推,*直到所有人出列为止,如此产生一个出列编号的序列...*解决方案:链表*/packagecom.jasxu;importjava.io.*;publicclassT4{/***@paramargs*/publicstaticvoidmain(String[]args){//
2、TODOAuto-generatedmethodstubtry{InputStreamReaderisr=newInputStreamReader(System.in);BufferedReaderbr=newBufferedReader(isr);System.out.println("请输入参加该游戏小孩的个数:");StringjoinNmu=br.readLine();System.out.println("请输入您想从编号为几的小孩开始报数?");Stringn1=br.readLine();S
3、ystem.out.println("请输入您想数到几的小孩出列?");Stringn2=br.readLine();intnum1=Integer.parseInt(n1);intnum2=Integer.parseInt(n2);intjoinLen=Integer.parseInt(joinNmu);CycLinkcyclink=newCycLink();cyclink.setLen(joinLen);cyclink.createLink();cyclink.setK(num2);cyclink.s
4、etM(2);cyclink.show();cyclink.play();}catch(Exceptione){e.printStackTrace();}}}//构建各个孩子classChild{//定义child的编号intno;//定义可以指向下一个的指针ChildnextChild=null;//创建构造函数publicChild(intno){//赋编号this.no=no;}}//构建一个环形链表classCycLink{//先定义一个指向链表第一个小孩的引用//指向第一个小孩的引用,不能动Ch
5、ildfirstChild=null;//定义一个游标,相当于跑龙套Childtemp=null;//定义一个表示大小的的len,表示共有几个小孩intlen=0;intk=0;intm=0;//构造函数,用来设置环形链表的大小publicvoidsetLen(intlen){this.len=len;}//设置m的值publicvoidsetM(intm){this.m=m;}//设置从第几个人开始数数publicvoidsetK(intk){this.k=k;}//游戏实现publicvoidplay
6、(){//设置跑龙套的小孩Childtemp=this.firstChild;//1.找到开始数数的人for(inti=1;i7、//4.数完了过后将数到m的小孩退出圈temp2.nextChild=temp.nextChild;//让temp指向下一个数数的小孩temp=temp.nextChild;this.len--;}//输出最后一个小孩System.out.println("最后出圈的小孩是:"+temp.no+"号小孩!");}//初始化环形链表publicvoidcreateLink(){//统计有多少个孩子for(inti=1;i<=len;i++){if(i==1){//首先创建第一个小孩Childch=newCh8、ild(i);//将第一个孩子的应用交给firstChildthis.firstChild=ch;//同时也要将引用交给跑龙套用this.temp=ch;}else{//判断是否是创建最后一个小孩if(i==len){//继续创建小孩Childch=newChild(i);//将temp的指针指向下一条地址的引用temp.nextChild=ch;//这条线相当于搭桥的线//桥答完后还要让temp指向刚刚创建的那个孩子temp
7、//4.数完了过后将数到m的小孩退出圈temp2.nextChild=temp.nextChild;//让temp指向下一个数数的小孩temp=temp.nextChild;this.len--;}//输出最后一个小孩System.out.println("最后出圈的小孩是:"+temp.no+"号小孩!");}//初始化环形链表publicvoidcreateLink(){//统计有多少个孩子for(inti=1;i<=len;i++){if(i==1){//首先创建第一个小孩Childch=newCh
8、ild(i);//将第一个孩子的应用交给firstChildthis.firstChild=ch;//同时也要将引用交给跑龙套用this.temp=ch;}else{//判断是否是创建最后一个小孩if(i==len){//继续创建小孩Childch=newChild(i);//将temp的指针指向下一条地址的引用temp.nextChild=ch;//这条线相当于搭桥的线//桥答完后还要让temp指向刚刚创建的那个孩子temp
此文档下载收益归作者所有