题解 | #孩子们的游戏(圆圈中最后剩下的数)#

孩子们的游戏(圆圈中最后剩下的数)

http://www.nowcoder.com/practice/f78a359491e64a50bce2d89cff857eb6

public class Solution {

    public class ListNode {
        public int val;
        public ListNode next;
        public ListNode pre;
        public ListNode(int val) {
            this.val = val;
        }
    }

    public int LastRemaining_Solution(int n, int m) {

        // 一些特殊情况的处理
        if (1 == n) {
            return 0;
        }

        // 小朋友们围成一圈
        // 初始化
        ListNode head = new ListNode(0);
        ListNode node = head;
        // 围成一圈
        for (int i = 1; i < n; i++) {
            ListNode tmp = new ListNode(i);
            tmp.pre = node;
            node.next = tmp;
            node = tmp;
        }
        head.pre = node;
        node.next = head;

        node = head;

        int account = 0;
        while (node.next != node) {
            account++;
            if (account ==
                    m) { // 当某名小朋友喊到 m 时,这名小朋友就要出队唱歌,同时可以拿礼物,并且不再回到圈中
                ListNode preNode = node.pre;
                ListNode nextNode = node.next;
                preNode.next = nextNode;
                nextNode.pre = preNode;
                account = 0; // 别忘了,计数器要重新归为 0
                node = nextNode;
            } else {
                node = node.next;
            }
        }
        return node.val;
    }
}
全部评论

相关推荐

11-09 14:54
已编辑
华南农业大学 产品经理
大拿老师:这个简历,连手机号码和照片都没打码,那为什么关键要素求职职位就不写呢? 从上往下看,都没看出自己到底是产品经理的简历,还是电子硬件的简历? 这是一个大问题,当然,更大的问题是实习经历的描述是不对的 不要只是去写实习流程,陈平,怎么去开会?怎么去讨论? 面试问的是你的产品功能点,是怎么设计的?也就是要写项目的亮点,有什么功能?这个功能有什么难处?怎么去解决的? 实习流程大家都一样,没什么优势,也没有提问点,没有提问,你就不得分 另外,你要明确你投的是什么职位,如果投的是产品职位,你的项目经历写的全都是跟产品无关的,那你的简历就没用 你的面试官必然是一个资深的产品经理,他不会去问那些计算机类的编程项目 所以这种四不像的简历,在校招是大忌
点赞 评论 收藏
分享
一名愚蠢的人类:多少games小鬼留下了羡慕的泪水
投递荣耀等公司10个岗位
点赞 评论 收藏
分享
头像
11-27 14:28
长沙理工大学
刷算法真的是提升代码能力最快的方法吗?&nbsp;刷算法真的是提升代码能力最快的方法吗?
牛牛不会牛泪:看你想提升什么,代码能力太宽泛了,是想提升算法能力还是工程能力? 工程能力做项目找实习,算法也分数据结构算法题和深度学习之类算法
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务