第九周项目1 猴子选大王(数组版)

2024-01-15 11:38

本文主要是介绍第九周项目1 猴子选大王(数组版),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


  1. 问题及代码:
  2. /* 
  3.  
  4. copyright (t) 2016,烟台大学计算机学院 
  5.  
  6. *All rights reserved. 
  7.  
  8. *文件名称:fangzhou.cpp 
  9.  
  10. *作者:吕方舟
  11.  
  12. *完成日期:2016年11月10日 
  13.  
  14. *版本号:v1.0 
  15.  
  16. *问题描述:一群猴子,编号是1,2,3 …m,这群猴子(m个)按照1-m的顺序围坐一圈。从第1只开始数,每数到第n个,该猴子就要离开此圈,这样依次下来,最后一只出圈的猴子为大王。输入m和n,输出猴子离开圈子的顺序,从中也可以看出最后为大王是几号猴子。  
  17.   要求采用数组作为存储结构完成。 
  18.  
  19. *输入描述:猴子数m与出圈报数n 
  20.  
  21. *程序输出:猴子离开圈子的顺序,以及最后为大王的猴子编号 
  22.  
  23. */  
  24. #include <stdio.h>  
    void findking(int m,int n)  
    {  int a[100];  int i,j,t;  for(i=0;i<m;i++)                       //m只猴子编号  a[i]=i+1;  t=0;                                   //首次报数的起始位置,并记录出圈猴子编号  printf("猴子出圈顺序为:\n");  for(i=m;i>=1;i--)  {  t=(t+n-1)%i;                       //出圈猴子编号  printf("%d ",a[t]);                //编号为t的猴子出圈  for(j=t+1;j<=i-1;j++)              //后面的元素前移一个位置  a[j-1]=a[j];  if(i==1)  printf("大王为%d\n",a[t]);  }  printf("\n");  
    }  
    int main()  
    {  int m,n;  printf("请输入猴子数m与出圈报数n:\n");  while(scanf("%d %d",&m,&n)!=EOF)  findking(m,n);  return 0;  
    } 
    运行结果:

  25. 知识点总结:
  26. 数组存储结构的应用。
  27. 学习心得:
  28. 之前用链表解决过这个问题,再次用数组解决感觉更简洁了。



这篇关于第九周项目1 猴子选大王(数组版)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

javafx 如何将项目打包为 Windows 的可执行文件exe

《javafx如何将项目打包为Windows的可执行文件exe》文章介绍了三种将JavaFX项目打包为.exe文件的方法:方法1使用jpackage(适用于JDK14及以上版本),方法2使用La... 目录方法 1:使用 jpackage(适用于 JDK 14 及更高版本)方法 2:使用 Launch4j(

Docker集成CI/CD的项目实践

《Docker集成CI/CD的项目实践》本文主要介绍了Docker集成CI/CD的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、引言1.1 什么是 CI/CD?1.2 docker 在 CI/CD 中的作用二、Docke

SpringBoot项目引入token设置方式

《SpringBoot项目引入token设置方式》本文详细介绍了JWT(JSONWebToken)的基本概念、结构、应用场景以及工作原理,通过动手实践,展示了如何在SpringBoot项目中实现JWT... 目录一. 先了解熟悉JWT(jsON Web Token)1. JSON Web Token是什么鬼

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择

Jenkins中自动化部署Spring Boot项目的全过程

《Jenkins中自动化部署SpringBoot项目的全过程》:本文主要介绍如何使用Jenkins从Git仓库拉取SpringBoot项目并进行自动化部署,通过配置Jenkins任务,实现项目的... 目录准备工作启动 Jenkins配置 Jenkins创建及配置任务源码管理构建触发器构建构建后操作构建任务

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE

Nginx、Tomcat等项目部署问题以及解决流程

《Nginx、Tomcat等项目部署问题以及解决流程》本文总结了项目部署中常见的four类问题及其解决方法:Nginx未按预期显示结果、端口未开启、日志分析的重要性以及开发环境与生产环境运行结果不一致... 目录前言1. Nginx部署后未按预期显示结果1.1 查看Nginx的启动情况1.2 解决启动失败的

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p