Tauruser
Enjoy Every Day
posts - 34, comments - 95, trackbacks - 0, articles - 5
C++博客
::
首页
::
新随笔
::
联系
::
聚合
::
管理
Josephus问题非递归方法1解决办法
Posted on 2006-03-05 15:00
Tauruser
阅读(849)
评论(0)
编辑
收藏
引用
所属分类:
算法与数据结构
1
/**/
///////////////////////////////////////////////////////////////////////////
//
2
///
算法与数据结构 Josephus 问题解决方案
///
3
///
用方法一非递归进行出列运算源程序
///
4
///////////////////////////////////////////////////////////////////////////
//
5
6
7
#include
<
iostream
>
8
using
namespace
std;
9
10
int
n,s,m;
//
设置全局变量
11
int
*
seat;
//
数组指针,指向各座位,注意这里以系统内部index base 0为准。
12
int
main()
13
{
14
//
参数输入
15
cout
<<
"
please input n:
"
;
16
cin
>>
n;
17
cout
<<
"
please input s:
"
;
18
cin
>>
s;
19
cout
<<
"
plesae input m:
"
;
20
cin
>>
m;
21
//
分配座位表空间
22
seat
=
new
int
[n];
23
//
对各座位上people的编号
24
for
(
int
i(
0
);i
<
n;i
++
)
25
{
26
seat[i]
=
i
+
1
;
27
}
28
29
30
//
将变量转化为系统内部index base 0;
31
s
--
;
32
33
//
方便需要
34
m
--
;
35
36
int
temp;
37
38
for
(
int
i
=
0
;i
<
n;i
++
)
39
{
40
s
=
(s
+
m)
%
(n
-
i);
//
第S位被OUT,s base 0;
41
if
(s
!=
n
-
i
-
1
)
//
当s=n-i-1时并不需要进行移位
42
{
43
temp
=
seat[n
-
i
-
1
];
44
seat[n
-
i
-
1
]
=
seat[s];
45
for
(
int
j
=
s;j
<
n
-
i
-
2
;j
++
)
46
seat[j]
=
seat[j
+
1
];
47
seat[n
-
i
-
2
]
=
temp;
48
}
49
50
}
51
52
//
输出出列顺序表
53
cout
<<
"
the out people list is:
"
;
54
for
(
int
i
=
n
-
1
;i
>=
0
;i
--
)
55
cout
<<
"
P
"
<<
seat[i]
<<
"
"
;
56
57
//
释放座位数组空间
58
delete []seat;
59
60
return
0
;
61
}
只有注册用户
登录
后才能发表评论。
【推荐】100%开源!大型工业跨平台软件C++源码提供,建模,组态!
相关文章:
Josephus问题递归方法2解决办法
Josephus问题非递归方法2解决办法
Josephus问题递归方法1解决办法
Josephus问题非递归方法1解决办法
网站导航:
博客园
IT新闻
BlogJava
博问
Chat2DB
管理
Powered by:
C++博客
Copyright © Tauruser
日历
<
2025年1月
>
日
一
二
三
四
五
六
29
30
31
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
1
2
3
4
5
6
7
8
公告
常用链接
我的随笔
我的评论
我参与的随笔
留言簿
(7)
给我留言
查看公开留言
查看私人留言
随笔分类
(16)
MFC(2)
计算机图形学(2)
密码学
数学模型
数值计算(2)
算法与数据结构(9)
信息论(1)
随笔档案
(34)
2007年3月 (1)
2007年2月 (2)
2007年1月 (1)
2006年10月 (1)
2006年6月 (3)
2006年5月 (5)
2006年4月 (6)
2006年3月 (14)
2006年2月 (1)
文章分类
(5)
密码学
数学模型
数值计算
算法与数据结构(4)
网络(1)
信息论
文章档案
(5)
2006年4月 (1)
2006年3月 (4)
相册
文章贴图
收藏夹
(3)
我的收藏(3)
协议
流媒体
中国协议网
友情链接
Orlaa
最新随笔
1. CListCtrl For Beginners(转载)
2. 结构体对齐的具体含义(#pragma pack) (转载)
3. MFC ComboBox 使用方法(转载)
4. 05年写的直线裁剪算法
5. C# Coding时的注释格式(zz)
6. 查找字符串的哈希方法(zz)
7. 木马客户端与服务端通讯如何隐藏不被发现
8. Gauss消去法直接求解方程组(附例程)
9. 使用AsycnSocket类进行简单双机通讯
10. Romberg求积(例程)
搜索
积分与排名
积分 - 105270
排名 - 237
最新评论
1. re: 双链表模版类的实现
问下:关于查找(search)那部分,我有点小问题要问,就是你直接就靠默认的比较操作符来比较,而你所用的是模版,链表支持各种类型,那么是字符串类型的链表或自定义类型的呢,你该怎么办
--周晓荣
2. re: OnSize()加入处理函数后,DEBUG报告出错
评论内容较长,点击标题查看
--NULL
3. re: C风格字符串与标准库string类型性能对比
评论内容较长,点击标题查看
--Hzj_jie
4. re: 05年写的直线裁剪算法
你这个算法也太复杂了吧
--啊啊啊啊啊啊
5. re: C++ Primer Fourth Edition (download file)
i want english edition
--zhccc
阅读排行榜
1. MFC ComboBox 使用方法(转载)(18713)
2. 结构体对齐的具体含义(#pragma pack) (转载)(11405)
3. Tab Control控件使用的例子(zz)(8346)
4. VC++2005 比 VC++ 6.0 退步了?(7517)
5. MAC地址有合法不合法之分吗?(7487)
评论排行榜
1. C风格字符串与标准库string类型性能对比(20)
2. VC++2005 比 VC++ 6.0 退步了?(12)
3. OnSize()加入处理函数后,DEBUG报告出错(8)
4. 为什么在VS2005重载输出运算符那么难?(7)
5. Gauss消去法直接求解方程组(附例程)(7)