您现在的位置: 中国男护士网 >> 考试频道 >> 计算机等级 >> 二级辅导 >> JAVA >> 辅导 >> 正文    
  约瑟夫环算法的Java实现代码 【注册男护士专用博客】          

约瑟夫环算法的Java实现代码

www.nanhushi.com     佚名   不详 

  相信大家都知道这是一个著名的算法问题,约瑟夫环的c语言实现是利用了指针链表的形式,java实现呢,我的这个是用了内部类.
  算法描述:n个人围成一圈,每人有一个各不相同的编号,选择一个人作为起点,然后顺时针从1到k数数,每数到k的人退出圈子,圈子缩小,然后从下一个人继续从1到k数数,重复上面过程。求最后推出圈子的那个人原来的编号。

程序实现:
public class JosephCircle {   
    private class Node {   
        public Node nextnode;   
  
        public boolean flag;   
    }   
  
    private Node[] list;   
  
    public JosephCircle() {   
        list = new Node[30];   
        int i;   
        for (i = 0; i < 30; i++) {   
            Node node = new Node();   
            node.flag = true;   
            if (i > 0) {   
                list[i - 1].nextnode = node;   
            }   
            list[i] = node;   
        }   
        list[i - 1].nextnode = list[0];   
    }   
  
    public void start() {   
        Node node = list[29];   
        for (int i = 0; i < 135; i++) {   
            if ((i+1) % 8 == 0) {    
                 node.flag = false;   
                node.nextnode = node.nextnode.nextnode;   
            } else {   
                node = node.nextnode;   
            }   
        }   
    }   
  
    public void print() {   
        Node node = list[29];   
        for (int i = 0; i < 30; i++) {   
            if (node.flag) {   
                System.out.print("#");   
            } else {   
                System.out.print("@");   
            }   
            node = node.nextnode;   
        }   
    }   
  
    public static void main(String[] args) {   
        JosephCircle jc = new JosephCircle();   
        jc.start();   
        jc.print();   
    }   
}  

 

文章录入:杜斌    责任编辑:杜斌 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
     

    联 系 信 息
    QQ:88236621
    电话:15853773350
    E-Mail:malenurse@163.com
    免费发布招聘信息
    做中国最专业男护士门户网站
    最 新 热 门
    最 新 推 荐
    相 关 文 章
    没有相关文章
    专 题 栏 目

      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)                            【进男护士社区逛逛】
    姓 名:
    * 游客填写  ·注册用户 ·忘记密码
    主 页:

    评 分:
    1分 2分 3分 4分 5分
    评论内容:
  • 请遵守《互联网电子公告服务管理规定》及中华人民共和国其他各项有关法律法规。
  • 严禁发表危害国家安全、损害国家利益、破坏民族团结、破坏国家宗教政策、破坏社会稳定、侮辱、诽谤、教唆、淫秽等内容的评论 。
  • 用户需对自己在使用本站服务过程中的行为承担法律责任(直接或间接导致的)。
  • 本站管理员有权保留或删除评论内容。
  • 评论内容只代表网友个人观点,与本网站立场无关。