题解 | #环形链表的约瑟夫问题#

环形链表的约瑟夫问题

http://www.nowcoder.com/practice/41c399fdb6004b31a6cbb047c641ed8a

package org.example.test;

import java.util.HashSet;
import java.util.Set;

public class YSFTest {

    public static void main(String[] args) {
        YSFTest test = new YSFTest();
        System.out.println(test.ysf(5, 2));
    }

    static class Node {
        int val;
        Node next;

        public Node(int val) {
            this.val = val;
        }
    }

    Node pre;

    // 用一个单链表形成环,并保存一个前节点,每次遍历删除一个节点,直到节点个数为1。
    public int ysf(int n, int m) {
        // write code here
        Node head = new Node(1);
        Node cur = head;
        for (int k = 2; k <= n; k++) {
            Node node = new Node(k);
            cur.next = node;
            cur = cur.next;
            if (k == n) {
                pre = node;
                cur.next = head;
                cur = head;
            }
        }
        int i = 1;
        Node next;
        while (head.next != null) {
            next = head.next;
            if (i == m) {
                pre.next = next;
                head = next;
                i = 1;
                if (pre == head) {
                    break;
                }
                continue;
            }
            pre = head;
            head = next;
            i++;
        }
        return head.val;
    }
}

全部评论

相关推荐

小红书 后端开发 总包n+8w+期权
点赞 评论 收藏
分享
10-24 13:36
门头沟学院 Java
Zzzzoooo:更新:今天下午有hr联系我去不去客户端,拒了
点赞 评论 收藏
分享
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-27 10:28
点赞 评论 收藏
分享
评论
2
收藏
分享
牛客网
牛客企业服务