Josephus问题解决方法一
2015-10-20 01:49
232 查看
关于该问题简单描述:假设有n个人排成一个圈。从第一个人开始报数,数到第m个人的时候这个人从队列里出列。然后继续在环里数后面第m个人,让其出列直到所有人都出列。最后一个出列的是胜出者。下面用链表模拟n个同学手拉手围成一个圈。如果m为1的话,该游戏没有了意思,因为这样的话,第n个人一定是胜出者,所以排除这种情况。解决该问题,有很多方法,本方法用的是循环单链表。如有不当之处,请读者指正!
#include<iostream>
//#include<stdlib.h>
using namespace std;
struct Note {
int data;
struct Note *next;
};
Note *CreateNote() {
Note *first;
first = new Note; //first = (Note *)malloc(sizeof(Note));
first ->data = NULL; //创建头结点,并且不存放任何值
return first;
}
Note *InitNote(Note *first, int n) {
Note *head, *p;
head = first;
p = NULL;
cout << "同学开始座次:" << endl;
for (int i = 1; i <= n; i++) { //利用尾插法,构造链表
p = new Note;
head->next = p;
p->data = i;
cout << p->data << "--> ";
head = p;
}
p->next = first->next; //形成换
return first; //返回第一个结点
}
void Search(Note *q, int m) {
cout << "依次出列同学:";
if (m == 1) { //如何查找间隔为1,则终止程序
cout << "游戏太无聊!";
exit(-1);
}
for (int i = 1; q != q->next; q = q->next, i++) {
if (i == m) { //当i = m时,执行其中的语句,并初始化i = 1,至于原因,读者画图便可知
i = 1;
Note *n;
n = q->next;
cout << q->next->data << "--> ";
q->next = n->next;
delete n;
}
}
cout << q->data;
cout << endl;
cout << "获胜的是:" << q->data << "号同学" << endl;
}
int main() {
Note *p, *q;
p = CreateNote();
q = InitNote(p, 5);
cout << endl;
Search(q, 2);
}
#include<iostream>
//#include<stdlib.h>
using namespace std;
struct Note {
int data;
struct Note *next;
};
Note *CreateNote() {
Note *first;
first = new Note; //first = (Note *)malloc(sizeof(Note));
first ->data = NULL; //创建头结点,并且不存放任何值
return first;
}
Note *InitNote(Note *first, int n) {
Note *head, *p;
head = first;
p = NULL;
cout << "同学开始座次:" << endl;
for (int i = 1; i <= n; i++) { //利用尾插法,构造链表
p = new Note;
head->next = p;
p->data = i;
cout << p->data << "--> ";
head = p;
}
p->next = first->next; //形成换
return first; //返回第一个结点
}
void Search(Note *q, int m) {
cout << "依次出列同学:";
if (m == 1) { //如何查找间隔为1,则终止程序
cout << "游戏太无聊!";
exit(-1);
}
for (int i = 1; q != q->next; q = q->next, i++) {
if (i == m) { //当i = m时,执行其中的语句,并初始化i = 1,至于原因,读者画图便可知
i = 1;
Note *n;
n = q->next;
cout << q->next->data << "--> ";
q->next = n->next;
delete n;
}
}
cout << q->data;
cout << endl;
cout << "获胜的是:" << q->data << "号同学" << endl;
}
int main() {
Note *p, *q;
p = CreateNote();
q = InitNote(p, 5);
cout << endl;
Search(q, 2);
}
相关文章推荐
- Swift中的打印日志的配置
- Buaaclubs的NABC与发布
- Greedy:Stripes(POJ 1826)
- Swift2.0——构造方法的使用
- java 虚拟机的生命周期
- [POJ 1511]Invitation Cards[链式前向星][SPFA]
- Swift基础篇——析构方法
- python多维数组初始化后赋值的问题
- u3d_Shader_effects笔记2 自定义surfaceDiffuseLight
- Swift基础篇——内外函数
- AD8275 Driver Amplifiers For Analog-To-Digital Converters
- Swift基础篇——内存相关
- Swift基础篇——枚举
- Swift基础篇——可选值
- Xpath基本用法详解
- POJ 1159 Palindrome
- Swift基础篇——结构体
- Ember.js 入门指南——查询记录
- Swift基础篇——单例
- Swift基础篇——懒加载