C语言数据结构中约瑟夫环问题如何解决


本文小编为大家详细介绍“C语言数据结构中约瑟夫环问题如何解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言数据结构中约瑟夫环问题如何解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。约瑟夫环问题的一种描述是:将编号为1,2,…n的n个人按顺时针方向围坐一圈,每人持有一个密码(正整数)。一开始任选一个正整数作为报数上限值m,从第一个人开始按顺时针方向自1开始顺序报数,报道m时停止报数。报m的人出列,将他的密码作为新的m值,从他在顺时针方向上的下一个人开始重新从1报数,如此下去,直至所有人全部出列为止。设计一个程序求出出列顺序。利用单向循环链表存储结构模拟此过程,按照出列的顺序印出个人的编号。m的初值为20;n = 7,7个人的密码依次为:3,1,7,2,4,8,4,首先m值为6(正确的出列顺序应为6,1,4,7,2,3,5)。用的是数组索引。结合一点点的算法知识。利用单项循环链表的方式,上干货运用的函数:创建链表取得链表的下标删除链表指定下标的元素得到第i个元素值数据结构的定义:结构体 LNode,成员包括:原始下标,元素值主函数的思路:其中上面的函数都是参考《数据结构(C语言版)》上面。只是将创建链表的函数改成创建单向循免费云主机域名环链表的函数。写代码主要时间消耗在主函数上。主函数的思路:创建一个指定大小(n)的循环链表,每一次循环得到第m个元素,记录此元素的下标,然后移动头结点到删除元素前面的结点,再把此时的头节点后面1一个结点给删除。依次遍历到n个。读到这里,这篇“C语言数据结构中约瑟夫环问题如何解决”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注百云主机行业资讯频道。

相关推荐: Python类的基本使用方法有哪些

本篇内容主要讲解“Python类的基本使用方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python类的基本使用方法有哪些”吧!1、面向对象类(class):是一种用来描述具有相同属性和方法的对象的集合。…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 03/07 12:11
下一篇 03/07 12:37

相关推荐