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

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

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;
    }
}
全部评论

相关推荐

半解316:内容充实,细节需要修改一下。 1,整体压缩为一页。所有内容顶格。 2,项目描述删除,直接写个人工作量 修改完之后还需要建议,可以私聊
点赞 评论 收藏
分享
06-23 11:43
门头沟学院 Java
allin校招的烤冷面很爱看电影:我靠,今天中午我也是这个hr隔一个星期发消息给我。问的问题还是一模一样的😅
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务