「题解」环形链表的约瑟夫问题

文章目录

  • 🍉题目
  • 🍉解析
    • 🍌创建环形链表
    • 🍌释放指定节点
    • 🍌其他思路
  • 🍉写在最后

🍉题目

在这里插入图片描述

🍉解析

题目的意思就是从环形链表的第一个节点开始数,数到第 m 的时候释放对应的节点,然后从下个节点又从1开始数,然后继续释放节点。所以我们要做的就是通过循环不断删除指定位置的节点。比如有5个节点,在删除第二个节点之前,得先让第一个节点的 next 指向第三个。
不过题目现在还没有链表,我们得先来创建一个。

(下面这个图演示有五个节点,m = 2的情况,绿色箭头表示删除某些节点之后剩余节点 next 指针的指向)

在这里插入图片描述

🍌创建环形链表

环形链表和单链表的区别在于,环形它最后一个节点的 next 指向的是第一个节点而非NULL,
既然首尾节点有这种联系,那一开始就得建立这两个指针pheadptail,等下创建链表的时候ptail就在循环中不断往后走,当它走到最后一个节点时,就让该节点的next指向第一个节点。
既然要产生节点,那么先来写个创建节点的函数(前面的文章有讲),代码如下:

ListNode* BuyListNode(int i) {
    ListNode* node = (ListNode*)malloc(sizeof(ListNode));
    node->val = i;
    node->next = NULL;
    return node;
}

接下来要创建链表,这个也不难:

ListNode* CreatListNode(int n) {
    ListNode* phead = BuyListNode(1);
    ListNode* ptail = phead;
    for (int i = 2;i <= n ; i++) {   //注意循环从 i == 2开始
        ListNode* node = BuyListNode(i);
        ptail->next = node;
        ptail = ptail->next; 
    }
    ptail->next = phead;
    return ptail;
}

注意:
①题目有说节点个数可以为1,检查下节点数为1有没有问题,此时首尾节点是同一个,而且不会进入循环,没问题。
②这里返回的是ptail,因为返回它的话我们很容易就能找到phead,而如果返回phead,那要找ptail的话还要遍历链表。

🍌释放指定节点

因为涉及到多次释放节点,不难想到应该要用while循环,那循环终止条件是啥呢?暂时看不出来,先把循环里面的东西写一下再说。

在这里插入图片描述

如上图,调用创建链表函数后,我们用prev接收返回的节点地址(其实就是尾节点),然后定义一个phead(prev->next)作为头指针,再来一个计数器,只要计数器的值为m,就先让prev保存phead的下一个节点,然后删除phead所指节点,然后让phead走向下一节点;若 count 不为m,则让pheadprev都前进一步。下面再画个图方便你理解这个过程。

在这里插入图片描述
在这里插入图片描述

再来说下循环结束条件,按照我刚才上面画的图,按那个走势走下去,最后只剩下节点3,此时pheadphead的next重合了,就可以出循环了,然后返回节点的值。

所以代码如下:

int ysf(int n, int m ) {
    ListNode* prev = CreatListNode(n);
    ListNode* phead = prev->next;
    int count = 1;  
    while (phead->next != phead) {
        
        if(count == m) {
            prev->next = phead->next;
            free(phead);
            phead = prev->next;
            count = 1;   //注意count一定要置为1!
        } else {
            prev = phead;
            phead = phead->next;
            count++;
        }
    }
    return phead->val;
}

整道题的代码如下:

typedef struct ListNode ListNode;

ListNode* BuyListNode(int i) {
    ListNode* node = (ListNode*)malloc(sizeof(ListNode));
    node->val = i;
    node->next = NULL;
    return node;
}

ListNode* CreatListNode(int n) {
    ListNode* phead = BuyListNode(1);
    ListNode* ptail = phead;
    for (int i = 2;i <= n ; i++) {
        ListNode* node = BuyListNode(i);
        ptail->next = node;
        ptail = ptail->next; 
    }
    ptail->next = phead;
    return ptail;
}

int ysf(int n, int m ) {
    ListNode* prev = CreatListNode(n);
    ListNode* phead = prev->next;
    int count = 1;
    while (phead->next != phead) {
        
        if(count == m) {
            prev->next = phead->next;
            free(phead);
            phead = prev->next;
            count = 1;
        } else {
            prev = phead;
            phead = phead->next;
            count++;
        }
    }
    return phead->val;
}

🍌其他思路

在上面演示的例子中,你也可以定义pheadpcur,其中pcur指向第二个节点,不过此时count的初始值要置为2。

🍉写在最后

如果你觉得本文写得还不错的话,那就点个小小的赞和关注喔,你们的支持是我更新的不懈动力!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/132331.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

CMake教程--QT项目使用CMake

CMake教程--QT项目使用CMake Chapter1 CMake教程--QT项目使用CMake1. Basic Cmake Based Project2. Executable VS Library3. Every module has its own CMakeList.txt in its folder3.1 不推荐的做法&#xff1a;3.2 推荐的做法 4. 强制以Debug, Release, RelWithDebInfo, Min…

Mac安装与配置eclipse

目录 一、安装Java&#xff1a;Mac环境配置&#xff08;Java&#xff09;----使用bash_profile进行配置&#xff08;附下载地址&#xff09; 二、下载和安装eclipse 1、进入eclipse的官网 (1)、点击“Download Packages ”​编辑 (2)、找到macOS选择符合自己电脑的框架选项…

人工智能基础_机器学习023_理解套索回归_认识L1正则---人工智能工作笔记0063

然后上一节我们说了L1,L2正则是为了提高,模型的泛化能力, 提高泛化能力,实际上就是把模型的公式的w,权重值,变小对吧. 然后我们这里首先看第一个L1正则,是怎么做到把w权重变小的 可以看到最上面是线性回归的损失函数,然后 L1可以看到,这个正则,就是在损失函数的基础上给损失…

轻松按需缩放图片像素——批量处理图片,满足不同需求!

在图片使用过程中&#xff0c;我们经常需要按照不同的要求调整图片的像素大小。如果一张一张地手动调整&#xff0c;不仅耗时而且容易出错。这款软件可以帮助您轻松实现批量处理图片&#xff0c;按需缩放图片像素&#xff0c;让您的图片管理更加高效、便捷&#xff01; 第一步…

Vuex持久化插件

Vuex数据默认是存储在内存中的&#xff0c;当然我们也可以将它存储在Local Storage&#xff0c;也可以指定某些数据存储在Local Storage 这样我们就用到了Vuex持久化插件vuex-persistedstate 安装vuex-persistedstate插件 npm install vuex-persistedstate --save 案列&#x…

MPSO-WPA

MPSO-WPA算法 DCAP means ’ discretized Cauchy’s argument principle’ 辅助信息 作者未提供代码

数据结构线性表——带头双向循环链表

前言&#xff1a;小伙伴们好久不见啦&#xff0c;上篇文章我们一起学习了数据结构线性表其一的单链表&#xff0c;了解了单链表的不少好处&#xff0c;但是不可能有完美的数据结构&#xff0c;就算是单链表&#xff0c;也会有很多缺点。 那么今天这篇文章&#xff0c;我们就来…

node插件MongoDB(五)—— 库mongoose 的模块化(五)

文章目录 一、使用mongoose 模块化的原因二、准备工作2. 启动mongo.exe 和mongod.exe 两个程序连接数据库 三、基本模块的拆分1、基本逻辑2、代码3、代码图示说明 四、在index.js 中进一步的拆分1.拆分原因2.新建model文件夹存储文档的结构对象3.代码4.代码实际演示和注意点 一…

用volta管理不同项目node版本

1 什么是volta volta是一个node.js的版本管理工具&#xff0c;你的电脑上安装了很多个node版本&#xff0c;volta可以让你在不同的项目中使用不同版本的node.js,并且可以切换node.js版本 Volta会自动将安装的Node.js版本与该项目绑定&#xff0c;使得您在该项目中执行 node、np…

Linux centos系统中添加磁盘

为了学习与训练文件系统或磁盘的分区、格式化和挂载/卸载&#xff0c;我们需要为虚拟机添加磁盘。根据需要&#xff0c;可以添加多块不同大小的磁盘。具体操作讨论如下&#xff0c;供参考。 一、添加 1.开机前 有两个地方&#xff0c;可选择打开添加硬盘对话框 (1)双击左侧…

2024“点点点”测试员如何上岸测试开发岗?附完整学习路线

有很多人员会不断问自己&#xff0c;自己到底要不要学测试&#xff0c;或者要不要坚持做测试&#xff0c;测试的职业发展到底怎么样&#xff1f;如果你还在迷茫&#xff0c;在到处找各种大牛问类似的问题&#xff0c;我希望这篇文章&#xff0c;你看完能够结束你的这个烦恼&…

iPad系列将在2024年全面更新!

今年还会有新iPad发布吗&#xff1f;答案是否定的。因为早在前几天的季度电话会议上&#xff0c;苹果公司CEO蒂姆・库克就已经宣布&#xff0c;今年不会推出任何新的iPad产品。 这也意味着&#xff0c;今年将是苹果公司自2010年推出首款iPad设备以来&#xff0c;第一次没有发布…

模块化之CJS, AMD, UMD 和 ESM

[[toc]] 模块化优点 防止命名冲突代码复用高维护性CJS, AMD, UMD 和 ESM 历史 ES6之前,JS一直没有自己的模块体系后来社区出现了CommonJS和AMD,CommonJS 主要用于服务器(Node)AMD 主要用于浏览器ES6引入了ESM到此,JS终于有了自己的模块体系,基本上可以完全取代CJS和AMD…

Java基础-面向对象进阶-多态, 包, final, 权限修饰符,代码块

Java基础-面向对象进阶-多态, 包, final, 权限修饰符,代码块 多态多态的概述多态中调用成员的特点多态的优势和弊端多态练习 包final权限修饰符代码块来源Gitee地址 多态 多态的概述 多态: 对象的多种形态多态的前提 有继承/实现关系有父类引用指向子类对象有方法的重写 多态…

ScrollView 与 SliverPadding 的关系

基本页面布局 Scaffold 中有个 ListView&#xff0c;ListView 中有 100 个高 50 的 Container 用作辅助观看&#xff0c;ListView 中第三个元素是一个 GridView&#xff0c;GridView 的滑动效果被禁止。 class GiveView extends GetView<GiveController> {const GiveVi…

【Unity之UI编程】编写一个面板交互界面需要注意的细节

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;Uni…

【Java】基于SpringBoot创建Web页面并热更新

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍基于SpringBoot创建Web页面并热更新。 学其所用&#xff0c;用其所学。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一下&#xff0c;下…

低价寄快递寄件微信小程序 实际商用版,对接了低价快递渠道,运营平台赚取差价,支持市面上全部主流快递

盈利模式 快递代下CPS就是用户通过线上的渠道&#xff08;快递小程序&#xff09;&#xff0c;线上下单寄快递来赚取差价&#xff0c;例如你的成本价是5元&#xff0c;你在后台比例设置里面设置 首重利润是1元&#xff0c;续重0.5元&#xff0c;用户下1kg的单页面显示的就是6元…

前端和空字符串、零比较时请务必使用===

在前端开发中遇到一个问题&#xff0c;以下两条语句的结果都是true。 console.log(0 ""); console.log(false ""); 这就导致了editingId为0的时候&#xff0c;if分支并没有执行&#xff0c;而我的本意是当editingId不是空也不是空字符串的时候执行分支…

SpringBoot 缓存之 @Cacheable 详细介绍

一、简介 1、缓存介绍 Spring 从 3.1 开始就引入了对 Cache 的支持。定义了 org.springframework.cache.Cache 和 org.springframework.cache.CacheManager 接口来统一不同的缓存技术。并支持使用 JCache&#xff08;JSR-107&#xff09;注解简化我们的开发。&#xfeff; 其…