设为首页
收藏本站
用户名
Email
自动登录
找回密码
密码
登录
立即注册
只需一步,快速开始
快捷导航
登录
注册
论坛首页
BBS
建站模版
微站设计
虚拟主机
企业邮箱
博客日志
Blog
搜索
搜索
搜索
热搜
长春
优惠
活动
做网站
本版
帖子
用户
本版
帖子
用户
请
登录
后使用快捷导航
没有帐号?
立即注册
道具
勋章
任务
留言板
设置
我的收藏
退出
时时商务社区
»
论坛首页
›
建站资源
›
建站技术
›
php基于环形链表解决约瑟夫环问题示例
返回列表
查看:
1723
|
回复:
0
php基于环形链表解决约瑟夫环问题示例
[复制链接]
新格网络
当前离线
积分
7789
2617
主题
2617
帖子
7789
积分
论坛元老
论坛元老, 积分 7789, 距离下一级还需 9992210 积分
论坛元老, 积分 7789, 距离下一级还需 9992210 积分
积分
7789
发消息
电梯直达
楼主
发表于 2018-2-14 05:22:16
|
只看该作者
|
倒序浏览
|
阅读模式
本文实例讲述了php基于环形链表解决约瑟夫环问题。分享给大家供大家参考,具体如下:
先来重温一下约瑟夫环问题:N个人围成一圈,从第一个开始报数,第M个将被杀掉,最后剩下一个,其余人都将被杀掉。例如N=6,M=5,被杀掉的顺序是:5,4,6,2,3,1。
前面介绍了
关联数组解决约瑟夫环的方法
,环形链表解决约瑟夫环的方法如下:
no=$no;
}
}
function addChild($n,&$first){ //$n是人的个数,创建环形链表
for($i=0;$inext=$cur;
}else{
$cur->next=$child;
$child->next=$first;
$cur=$cur->next;
}
}
}
function showHero($first){
$cur=$first;
while($cur->next!=$first){
echo "
人的编号:".$cur->no;
$cur=$cur->next;
}
echo "
人的编号:".$cur->no;
}
function countChild($first,$m,$k){
$cur=$first;
for($i=0;$inext;
}
$j=0;
while($cur!=$cur->next){
if($j==$k-2){
echo "
出列编号:".$cur->next->no;
$cur->next=$cur->next->next;
$cur=$cur->next;
$j=0;
}else{
$cur=$cur->next;
$j++;
}
}
echo "
最后出列编号:".$cur->no;
}
addChild(10,$first);
showHero($first);
echo "";
countChild($first,2,3); //第二个人开始数,数到三出列
?>
运行结果:
人的编号:1
人的编号:2
人的编号:3
人的编号:4
人的编号:5
人的编号:6
人的编号:7
人的编号:8
人的编号:9
人的编号:10
--------------------------------------------------------------------------------
出列编号:4
出列编号:7
出列编号:10
出列编号:3
出列编号:8
出列编号:2
出列编号:9
出列编号:6
出列编号:1
最后出列编号:5
更多关于PHP相关内容感兴趣的读者可查看本站专题:《
PHP数据结构与算法教程
》、《
php程序设计算法总结
》、《
php字符串(string)用法总结
》、《
PHP数组(Array)操作技巧大全
》、《
PHP常用遍历算法与技巧总结
》及《
PHP数学运算技巧总结
》
希望本文所述对大家PHP程序设计有所帮助。
您可能感兴趣的文章:
PHP基于双向链表与排序操作实现的会员排名功能示例
PHP小教程之实现双向链表
PHP实现双链表删除与插入节点的方法示例
PHP 双链表(SplDoublyLinkedList)简介和使用实例
php实现单链表的实例代码
PHP环形链表实现方法示例
PHP实现的基于单向链表解决约瑟夫环问题示例
PHP简单实现循环链表功能示例
PHP实现单链表翻转操作示例
PHP实现合并两个排序链表的方法
PHP双向链表定义与用法示例
分享到:
QQ好友和群
QQ空间
腾讯微博
腾讯朋友
收藏
0
回复
使用道具
举报
返回列表
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
本版积分规则
发表回复
回帖后跳转到最后一页
用户反馈
客户端