猴子选大王系统的设计与实现

2024-01-08 23:59

本文主要是介绍猴子选大王系统的设计与实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2. 猴子选大王系统的设计与实现

2.1 问题的描述

一堆猴子都有编号,编号是1,2,3 ...m ,这群猴子(m个)按照1--m的顺序围坐一圈,从第1开始数,每数到第N个,该猴子就要离开此圈,这样依次下来,直到圈中只剩下最后一只猴子,则该猴子为大王。

2.2 问题分析和任务定义

(1)输入数据:输入m,n。m,n 为整数,n<m;

(2)输出形式:中文提示按照m个猴子,数n 个数的方法,输出为大王的猴子是几号 ,建立一个函数来实现此功能。

2.3 数据类型和系统设计

1)存储结构设计

采用循环链表来存储“猴子的编号”,无需头结点。

2)系统功能设计

①创建循环链表;

②向单链表中填入猴子的编号;

③找到第一个开始报数的猴子;

④数到n让猴子出列;

⑤接着开始报数,重复第三步;只剩下最后一只猴子;

⑥输出猴子的信息。

2.4 编码实现

#include<stdio.h>

#include<stdlib.h>

(1)定义猴子群的结构体

typedef struct Node

{   int data;   //数据域,用来存储猴子编号

      struct Node *next;//指针域

}Node,*LinkList;

(2)创建一个链表,将猴子编号并入链表中

LinkList CreateList(int n)

{    int i;

      Node *head,*p;//定义两个指针变量

      head=(LinkList)malloc(sizeof(struct Node));

      head->next=head;

      for(i=1;i<n;++i)

      {   p=(LinkList)malloc(sizeof(struct Node));//申请头结点,并赋予空间

             p->next=head->next;

             head->next=p;

      }

      p=head;

      for(i=0;i<n;++i)

      {   p->data=i+1;

             p=p->next;

      }

      return head;//返回头指针

}

(3)循环遍历链表

int LinkedList(LinkList head,int num_monkey,int number)

{    int j=1,k;

      Node *p=head,*q;

      for(;num_monkey>1;num_monkey--)

      {            k=1;

             while(k!=number)

             {     p=p->next;

                    k++;

             }

             printf("第%d个出队列的是%d号猴子,\n",j++,p->data);

             p->data=p->next->data;

             q=p->next;

             p->next=p->next->next;

      }

      return p->data;

}

(4)主函数

int main()

{    int m,n,king;

      printf("请输入猴子个数:");

      scanf("%d",&m);

      LinkList head=CreateList(m);

      printf("请输入要报的数:");

      scanf("%d",&n);

      king=LinkedList(head,m,n);

      printf("%d号猴子是大王\n",king);

}

2.5 测试结果

筛选过程及结果,如图

   

 

 

这篇关于猴子选大王系统的设计与实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/585300

相关文章

Flutter实现文字镂空效果的详细步骤

《Flutter实现文字镂空效果的详细步骤》:本文主要介绍如何使用Flutter实现文字镂空效果,包括创建基础应用结构、实现自定义绘制器、构建UI界面以及实现颜色选择按钮等步骤,并详细解析了混合模... 目录引言实现原理开始实现步骤1:创建基础应用结构步骤2:创建主屏幕步骤3:实现自定义绘制器步骤4:构建U

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

Windows系统宽带限制如何解除?

《Windows系统宽带限制如何解除?》有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文就跟大家一起来看看Windows系统解除网络限制的操作方法吧... 有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设

电脑找不到mfc90u.dll文件怎么办? 系统报错mfc90u.dll丢失修复的5种方案

《电脑找不到mfc90u.dll文件怎么办?系统报错mfc90u.dll丢失修复的5种方案》在我们日常使用电脑的过程中,可能会遇到一些软件或系统错误,其中之一就是mfc90u.dll丢失,那么,mf... 在大部分情况下出现我们运行或安装软件,游戏出现提示丢失某些DLL文件或OCX文件的原因可能是原始安装包

电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案

《电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案》最近有不少兄弟反映,电脑突然弹出“mfc100u.dll已加载,但找不到入口点”的错误提示,导致一些程序无法正... 在计算机使用过程中,我们经常会遇到一些错误提示,其中最常见的就是“找不到指定的模块”或“缺少某个DL

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句