1. 约瑟夫问题

题目(要求用循环链表实现)

约瑟夫问题是一个经典的问题。已知n个人(不妨分别以编号1,2,3,...,n 代表 )围坐在一张圆桌周围,从编号为 k 的人开始,从1开始顺时针报数1, 2, 3, ...,顺时针数到m 的那个人,出列并输出。然后从出列的下一个人开始,从1开始继续顺时针报数,数到m的那个人,出列并输出,...依此重复下去,直到圆桌周围的人全部出列。

输入:n, k, m

输出:按照出列的顺序依次输出出列人的编号,编号中间相隔一个空格,每10个编号为一行。

非法输入的对应输出如下

a)

输入::n、k、m任一个小于1
输出:n,m,k must bigger than 0.

b)

输入:k>n

输出:k should not bigger than n.

例:

输入:9,3,2

输出:4 6 8 1 3 7 2 9 5


C++完整代码

cpp 复制代码
#include <iostream>
#include <string>
#include <vector>
using namespace std;

struct ListNode {
	int val;
	ListNode* next;
	ListNode(int x) : val(x), next(NULL) {}
};

int main() {
	int n, k, m;
	scanf("%d%*c%d%*c%d", &n, &k, &m);

	if (n < 1 || k < 1 || m < 1) {
		cout << "n,m,k must bigger than 0." << endl;
		return 0;
	}
	if (k > n) {
		cout << "k should not bigger than n." << endl;
		return 0;
	}

	// 创建循环链表
	ListNode* head = new ListNode(1);
	ListNode* cur = head;
	for (int i = 2; i <= n; i++) {
		cur->next = new ListNode(i);
		cur = cur->next;
	}
	cur->next = head;

	// 将cur指针移动到编号为k的节点
	for (int i = 0; i < k - 1; i++) {
		head = head->next;
	}
	int count = 0;
	// 开始报数并出列
	while (n) {
		if (m > 1) {// 数到m的前一个节点
			for (int i = 0; i < m - 2; i++) {
				head = head->next;
			}
			// 出列并记录编号
			ListNode* temp = head->next;
			cout<<temp->val;
			head->next = temp->next;
			head = head->next;
			delete temp;
			n--;
			count++;
		}
		else {
			cout<<head->val;
			head = head->next;
			n--;
		}
		if (n == 0 && count % 10 != 0) cout << endl;
		else if (count % 10 == 0) cout << endl;
		else cout << " ";
	}
	return 0;
}
相关推荐
点云SLAM13 小时前
算法与数据结构之二叉树(Binary Tree)
数据结构·算法·二叉树·深度优先·广度优先·宽度优先
_F_y13 小时前
C++异常
c++
小龙报13 小时前
《算法通关指南:算法基础篇 --- 一维前缀和 — 1. 【模板】一维前缀和,2.最大子段和》
c语言·数据结构·c++·算法·职场和发展·创业创新·visual studio
吴名氏.13 小时前
电子书《21天学通Java(第5版)》
java·开发语言·21天学通java
星释14 小时前
Rust 练习册 :深入探索XOR加密与流密码
开发语言·网络·rust
郝学胜-神的一滴14 小时前
Effective STL 第9条:C++容器元素删除技巧详解
开发语言·c++·程序人生·stl
提娜米苏14 小时前
Bash Shell脚本学习——唇读数据集格式修复脚本
开发语言·学习·bash
larance14 小时前
python中的鸭子类型
开发语言·python
树在风中摇曳14 小时前
LeetCode 1658 | 将 x 减到 0 的最小操作数(C语言滑动窗口解法)
c语言·算法·leetcode
Ma_Hong_Kai14 小时前
带复选框的combox
c++·mfc