IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 约瑟夫环问题 -> 正文阅读

[C++知识库]约瑟夫环问题

最近为了教学妹C语言,重新写了一下约瑟夫环问题。
结合代码讲解一下设计思路。

题目描述:
约瑟夫环(约瑟夫问题)是一个数学的应用问题:已知 num 个人(以编号1,2,3…num分别表示)围坐在一张圆桌周围。从编号为 1 的人开始报数,数到 k 的那个人出圈;他的下一个人又从 1 开始报数,数到 k 的那个人又出圈;依此规律重复下去,直到剩余最后一个胜利者。

代码设计思路:写一个传入两个参数的函数,num表示参与游戏的总人数,k表示数到k的幸运儿惨遭淘汰。

核心的循环代码为:

	for (i = 0; counter < num - 1; i++) {
		if (i == num) {
			i = 0;
		}
		if (a[i] == 1) {	// 报数轮到第i人且未被淘汰
			j++;			// 有效人数加一
			if (j == k) {	// 数到第k个活人时
				a[i] = 0;		// 淘汰i号人
				counter++;		// 淘汰人数+1
				j = 0;			// 有效人数归零
				printf("杀死%d\t",i);
			}
		}
	}

这个循环的功能是不断地进行报数,知道出现死者数量达到num-1时跳出循环。此时最后一个生还者即为胜利者。
初始时a[i]均为1,当被淘汰时就将该人状态置为0。此时将不参与报数。
j用来记录现在报的数字,每有一个人报数就进行j++。当j与k相等时进行淘汰。

#include<stdlib.h>
int main() {
	int JosephRing(int a, int b);  // 函数声明
	printf("%d", JosephRing(6, 4));
	return 0;
}


int JosephRing(int num, int k) {
	int a[100];
	int i, j = 0, ans=-1,counter=0;
	for (i = 0; i < num; i++) {
		a[i] = 1;
	}

	for (i = 0; counter < num - 1; i++) {
		if (i == num) {
			i = 0;
		}
		if (a[i] == 1) {	// 第 i人活着
			j++;			// 有效人数加一
			if (j == k) {	// 数到第k个活人时
				a[i] = 0;		// 杀死i号人
				counter++;		// 死人数+1
				j = 0;			// 有效人数归零
				printf("杀死%d\t",i);
			}
		}
	}
	for (i = 0; i < num; i++) {
		if (a[i] == 1) {
			ans = i;
		}
	}
	return ans;
}

以上为完整代码,复制即可运行。

这种做法不一定是最高效的,但我认为是非常符合正常的思维逻辑。有不少变量,编写代码时要明确每个变量的功能。作为C语言初学者入门题比较适合。

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-19 11:52:27  更:2021-08-19 11:54:49 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/20 11:34:47-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码