news 2026/5/26 6:18:07

C语言之约瑟夫问题

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C语言之约瑟夫问题

首先,编写一个程序,对m个人进行一次计数,即排成一行。如果达到出列要求,则重新计时。最后输出出列者的编号。

#include<stdio.h> int main() { int m,n,i,k; scanf("%d%d",&m,&n); int f[m];//该数组有m个元素,代表m个人的编号 for(i=0;i<m;i++){ f[i]=i+1;//存储每个人的编号 } k=0;//计数器清0 i=0;//从第一个人开始计数 while(i<m){//因为i的取值从0到m-1 k++;从第一个人开始数 if(k==n){//满足出列条件 printf("%-5d",f[i]);//输出出列者编号 k=0;//计数器复位,重新开始+1计数,再碰到符合出列数字的人出列。 } i++;//人的编号也要持续+1,且不用重置 } return 0; }

约瑟夫环是实现对m个人的循环计数,即数完第m个人后,重新回到第一个人继续计数,从而模拟m个人围成一圈的效果。

即实现约瑟夫环的关键是如何在计数完m个人后回到第1个人。即把i的条件变成i=(i+1)%m,能写出上述公式是因为要在i=m-2之前仍然是i++的效果,即余数为除数。但当i=m-1时,即最后一个人数完后,重新回到第1个人继续循环,即i变成0。但运行之后会发现,会无限循环,因为i的范围总是满足循环条件。所以要修改循环条件,最后剩余不足一个人时,即是循环结束的点。所以需要再定义一个变量是剩余人数。

同时,不要忘了把已经出列的人去掉。

#include<stdio.h> int main() { int m,n,i,k,c; scanf("%d%d",&m,&n); int f[m];//该数组有m个元素,代表m个人的编号 for(i=0;i<m;i++){ f[i]=i+1;//存储每个人的编号 } c=m; k=0;//计数器清0 i=0;//从第一个人开始计数 while(c>0){//因为i的取值从0到m-1 if(f[i]!=0){//再从下一个人开始计数时,就把已经出列的人排除即不数上。 k++; } if(k==n){ printf("%-5d",f[i]); f[i]=0;//出列的人序号清除 c--; k=0;//计数器复位,重新开始+1计数,再碰到符合出列数字的人出列。但这里唯一的问题是应该将已经出列的人排除再重新开始计数,即返回到第一个人。 } i=(i+1)%m; } return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/23 15:06:46

类变量和全局变量的作用域分别是什么?

类变量和全局变量的作用域核心差异在于可见范围的边界&#xff1a;全局变量的作用域是「整个模块」&#xff0c;类变量的作用域是「类的命名空间」&#xff08;及子类 / 实例&#xff09;。下面从定义、访问规则、边界限制、示例验证四个维度拆解&#xff0c;让作用域的边界更清…

作者头像 李华
网站建设 2026/5/23 20:17:38

LobeChat日志聚合分析方案

LobeChat 日志聚合分析方案 在AI聊天应用日益深入企业与个人工作流的今天&#xff0c;一个看似不起眼却至关重要的问题逐渐浮出水面&#xff1a;我们真的了解用户是如何使用这些智能对话系统的吗&#xff1f; 以开源项目 LobeChat 为例&#xff0c;它凭借对多模型支持、插件扩展…

作者头像 李华
网站建设 2026/5/25 14:53:54

Java全栈开发面试实战:从基础到高阶的深度对话

Java全栈开发面试实战&#xff1a;从基础到高阶的深度对话 一、面试开场 面试官&#xff1a;你好&#xff0c;欢迎来到我们公司的面试。我是今天的面试官&#xff0c;主要负责技术评估。今天我们会围绕你的项目经验、技术能力以及对业务的理解展开讨论。你可以先简单介绍一下自…

作者头像 李华
网站建设 2026/5/26 6:12:15

安卓端秒速AI绘图:denoising-diffusion移动化实战指南

安卓端秒速AI绘图&#xff1a;denoising-diffusion移动化实战指南 【免费下载链接】denoising-diffusion-pytorch Implementation of Denoising Diffusion Probabilistic Model in Pytorch 项目地址: https://gitcode.com/gh_mirrors/de/denoising-diffusion-pytorch 还…

作者头像 李华
网站建设 2026/5/25 21:58:50

LobeChat获客成本降低方案

LobeChat&#xff1a;如何用开源技术重构企业AI获客成本模型 在今天&#xff0c;一个看似简单的用户咨询——“你们的产品支持Linux吗&#xff1f;”——背后可能藏着一场关于成本与效率的激烈博弈。传统客服需要人力响应、等待转接、查阅文档&#xff1b;而如果处理不当&#…

作者头像 李华