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

环形链表的约瑟夫问题

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

核心思想
  • 成环, 返还tail结点
  • 初始化前哨指针,和当前指针
  • 遍历计数,当技术等于m了,则摘掉当前结点,从下个结点开始
  • 返回最一个指针,即当前指针的val
/**
 * 
 * @param n int整型 
 * @param m int整型 
 * @return int整型
 *
 * C语言声明定义全局变量请加上static,防止重复定义
 */
struct ListNode * createList(int n)
{
    int i = 1;
    struct ListNode * head = (struct ListNode *)malloc(sizeof(struct ListNode));
    head->val = i;
    head->next = NULL;
    struct ListNode * tail = head;

    i =2;
    while(i <= n)
    {
        struct ListNode * tmp = (struct ListNode *)malloc(sizeof(struct ListNode));
        tmp->val = i;
        tmp->next = NULL;
        tail->next = tmp;
        tail = tmp;
        i++;
    }
    
    tail->next = head;
    
    return tail;
}

int ysf(int n, int m ) {
    // write code here
    // 成环
    if(n == 1)
    {
        return n;
    }
    
    
    struct ListNode * tail = createList(n);
    struct ListNode * move = tail->next;
    // 设置前哨结点,和当前的move结点
    
    int count = 1;
    while(move->next != move)
    {
        
        if(count == m)
        {
            tail->next = move->next;
            move = tail->next;
            count = 1;
        }
        count++;
        move = move->next;
        tail = tail->next;
        
    }
    
    return move->val;
}




全部评论

相关推荐

2024-11-14 19:18
门头沟学院 软件测试
点赞 评论 收藏
分享
object3:开始给部分🌸孝子上人生第一课了
点赞 评论 收藏
分享
评论
3
收藏
分享
牛客网
牛客企业服务