算法整理学习(二)

(注:以下算法答案来自网络,自己整理供学习)

3.约瑟夫循环报数出列顺序问题

思路:采用循环链表,当然也可以采用数组,像模拟循环队列一样

//方法一: 采用找到一个节点删除一个节点的方式(递归版本)
////
template<typename T>
void Josephus(ListNode<T>* cur, int N)
{int i=1;ListNode<T>* trail=cur;if (cur->next == cur) //如果只剩一个节点,结束递归
    {cout<<" "<<cur->data<<"\n\n";delete cur;return;}while (i < N){i++;trail = cur;cur = cur->next;}trail->next=cur->next;cout<<" "<<cur->data<<" >";delete cur;Josephus(trail->next, N);
}//方法一: 采用找到一个节点删除一个节点的方式(循环版本)
////
template<typename T>
void Josephus(ListNode<T>* cur, int N)
{int i=1;ListNode<T>* trail=cur;while (cur->next != cur){for (i=1; i<N; i++){trail = cur;cur = cur->next;}trail->next=cur->next;cout<<" "<<cur->data<<" >";delete cur;cur = trail->next;}cout<<" "<<cur->data<<"\n\n";delete cur;}//方法二: 采用找到一个节点标识一个节点的方式
////
template<typename T>
void Josephus(ListNode<T>* cur, int cycle, int count)
{int i;while (count > 0){while (cur->data == -1) //用-1标示已出列的节点
        {cur = cur->next;}for (i=1; i<cycle; i++){cur = cur->next;while (cur->data == -1){cur = cur->next;}}cout<<" "<<cur->data<<" >";cur->data = -1;count--;}
}

 

 

转载于:https://www.cnblogs.com/wust0801/archive/2012/05/01/2478074.html

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python判断ip能否ping通_使用Python测试Ping主机IP和某端口是否开放的实例

使用Python方法比用各种命令方便&#xff0c;可以设置超时时间&#xff0c;到底通不通&#xff0c;端口是否开放一眼能看出来。命令和返回完整权限&#xff0c;可以ping通&#xff0c;端口开放&#xff0c;结果如下&#xff1a;无root权限(省略了ping)&#xff0c;端口开放&…

python实现抓取网页上的内容并发送到邮箱

要达到的目的&#xff1a;从特定网页中抓取信息&#xff0c;排版后发送到邮箱中 关键点&#xff1a;下载网页&#xff0c;从网页里抓取出需要的信息HTML排版发送到指定邮箱 实现&#xff1a;1.python下载网页直接用库函数就可以实现from urllib import urlretrievefrom urllib …

Thinkphp 配置不用输入index.php

版权声明&#xff1a;本文为博主原创文章&#xff0c;遵循 CC 4.0 BY-SA 版权协议&#xff0c;转载请附上原文出处链接和本声明。 本文链接&#xff1a;https://blog.csdn.net/u011186019/article/details/78495461由&#xff1a;http://127.0.0.1/thinkphp/index.php/index/in…

ue4导入倾斜摄影_倾斜摄影建模干货|还怕搞不定CC空三?这里只要5分钟……

关注公众号"三维前沿"&#xff0c;持续获取更多操作技巧干货&#xff01;01Q&#xff1a;空三刚开始就失败&#xff1f;A&#xff1a;考虑以下4种情况&#xff1a;考虑ContextCapture Engine 是否打开&#xff0c;尝试关闭后重新打开&#xff1b;考虑相片数量是否过多…

[html] 如何禁止移动端的左右划动手势?

[html] 如何禁止移动端的左右划动手势&#xff1f; html{touch-action:none;touch-action:pan-y;}个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面试题

python自增_python mysql自增字段AUTO_INCREMENT值的修改方式

在之前得文章中我们说过&#xff0c;如果使用delete对数据库中得表进行删除&#xff0c;那么只是把记录删除掉&#xff0c;并且id的值还会保持上次的状态。 即删除之前如果有四条数据&#xff0c;删除之后&#xff0c;再添加新的数据&#xff0c;id怎会从5开始。 但是我们显示想…

Python工具

1. sourcetree https://www.cnblogs.com/hoobey/p/7100593.html 2.pycharm 3. anaconda 转载于:https://www.cnblogs.com/ericazy/p/11498959.html

graphpad两组t检验_GraphPad prism -- t检验操作步骤解析~

ZSCIt检验&#xff0c;主要用于样本含量较小(例如 n<30)&#xff0c;总体标准差 σ 未知的正态分布资料&#xff0c;其中又将其分为了配对t检验和成组t检验&#xff0c;那如何利用GraphPad prism进行t检验呢&#xff1f;一、原理及意义配对t检验&#xff1a;又称配对样本均数…

[html] 在两个iframe之间传递参数的方法有哪些?

[html] 在两个iframe之间传递参数的方法有哪些&#xff1f; 通过postMessage与父级通过&#xff0c;父级传递消息通过websocket通信如果是同一个域名下可用stroage&#xff0c;监听storageChange事件通信通过web worker也可通信个人简介 我是歌谣&#xff0c;欢迎和大家一起交…

Java官方操纵byte数组的方式

java官方提供了一种操作字节数组的方法——内存流&#xff08;字节数组流&#xff09;ByteArrayInputStream、ByteArrayOutputStream ByteArrayOutputStream——byte数组合并 /*** 将所有的字节数组全部写入内存中&#xff0c;之后将其转化为字节数组*/public static void main…

python js返回 json_[python爬虫]把js转化成json

有一个优秀的库可以使用————demjson目标链接请求上面链接&#xff0c;会得到如下图的一个js文件我们需要把这个js文件转成为dict&#xff0c;方便提取其中需要的字段(这在爬虫任务中非常常见)失败的方法传统方法通常转js文件为dict的过程&#xff1a;1.先通过切片掐头去尾&…

springboot security 权限不足_springBoot整合springSecurity(零一)

整体结构》》》1&#xff0c;springboot2.0整合springSecurity5.1.12&#xff0c;mysql--->>InnoDB3&#xff0c;持久层我用的是用MybatiysPlus(这里就不写关于这个的了,基本是查)4&#xff0c;web服务不是jar服务5&#xff0c;数据库表》账户表/角色表/权限表/账户角色关…

聊聊PowerJob的OmsLogHandler

序 本文主要研究一下PowerJob的OmsLogHandler OmsLogHandler tech/powerjob/worker/background/OmsLogHandler.java Slf4j public class OmsLogHandler {private final String workerAddress;private final Transporter transporter;private final ServerDiscoveryService …

[html] 为什么移动端页面的设计稿一般是750px/640px呢?

[html] 为什么移动端页面的设计稿一般是750px/640px呢&#xff1f; 750px 代表iphone6或inphone6s 设备的像素(宽) 640px 代表inpone3Gs&#xff0c;inpone4/4s iphone5系列 设备的像素(宽) 其他手机大多数时这两种规格 750px/640px 代表的逻辑像素是 375px/320px&#xff0c;…

m文件中函数的执行顺序

当进行多个GUI协同工作时&#xff0c;要用到uiwait和uiresume函数。此时&#xff0c;理解函数的执行顺序此时是很关键的。 首先理解uiwait和uiresume函数的作用。 uiwait函数&#xff1a;阻塞m文件的执行&#xff0c;直到uiresume解除这种阻塞&#xff1b; uiresume函数&#x…

Java从string数组创建临时文件

//从string数组创建临时文件 private static File createSampleFile(String[] strs) throws IOException {File file File.createTempFile("aws-java-sdk-", ".txt");file.deleteOnExit();Writer writer new OutputStreamWriter(new FileOutputStream(fi…

关刀机器人_小学机器人活动总结

页眉内容开展青少年机器人创新实践活动情况个人总结为进一步推动我校机器人活动的普及与发展&#xff0c;培养学生对科技制作的兴趣&#xff0c;促进学生整体素质的提高&#xff0c;同时培养学生动手实践的能力&#xff0c;我校于2016年3月开展了机器人创新实践活动。在学校领导…

[html] iframe可以使用父页面中的资源吗(如:css、js等)?

[html] iframe可以使用父页面中的资源吗&#xff08;如&#xff1a;css、js等&#xff09;&#xff1f; iframe 属于一个单独的文档不能直接使用父页面的资源&#xff0c;css的层叠不会影响iframeiframe如果和父页面同域则可以在iframe中使用parent对象来使用父页的js对象个人简…

error LNK2001:unresolved external symbol __imp__@ 解决方法

我在程序Lan中使用了winsock函数&#xff0c;出现如下错误&#xff1a;Lan.obj&#xff1a;error LNK2001: unresolved external symbol __imp__listen8 Lan.obj : error LNK2001: unresolved external symbol __imp__bind12 Lan.obj : error LN…

[html] 怎么去除img之间存在的间隔缝隙?

[html] 怎么去除img之间存在的间隔缝隙&#xff1f; 1.修改display:block/flex&#xff0c; 2.父级设置font-size:0个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面试题…