C语言围圈报数题目代码实现

 更新时间:2022年01月02日 01:16:13   作者:我說  
大家好,本篇文章主要讲的是C语言围圈报数题目代码实现,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览

围圈报数 题目

解题步骤

一.整体逻辑

1.从第1个人开始报数,
2.数到第m个人出列,
3.然后从出列的下一个人开始报数,
4.数到第m个人又出列,…,如此反复到所有的人全部出列为止。

二.逻辑的实现

1.创造一个数组来记录人的信息
2.利用循环依次报数(当只剩下一个人的时候,循环结束(因为不需要报数了,直接输出就可以了))
3.输出报到m的人,并且将他标记起来(表示此人已出列)
4.最后输出剩下的那个人

三.代码的实现

#include<stdio.h>
#include<string.h>
#pragma warning(disable:4996)
int main()
{
	int n, m;
	scanf("%d %d", &n,& m);
	int* arr = (int*)malloc(sizeof(int) * (n+1));  //创造一个数组
	for (int i = 0; i <= n; i++)
	{
		arr[i] = i ;                       
	}
	int number = 0;//出列的人数
	int k = 0;
	int j = 1;
	while (number < n - 1)  //当只剩下一个人的时候推出
	{
		if (arr[j] != 0)//报数
		{
			k++;
		}	
		if (k == m)
		{
			printf("%d ", arr[j]);
			arr[j] = 0; //出列的人标记起来
			number++;
			k = 0;
		}
		j++;
		if (j == n+1)        //当最后一个人报完的时候,回到第一个人
			j = 1;
	}
	for (int i = 1; i <= n; i++)
	{
		if (arr[i] != 0)
			printf("%d", arr[i]);  //最后打印出剩下的一个人
	}
	return 0;
}

感悟

最近过得十分的压抑,感觉胸上压了块石头一样,我觉得根本上还是自己太堕落了,没有去努力,跟没有去朝着能实现自己人生目标和价值的方向去奋斗,所以才导致自己莫名的低落。所以我决定以后每天写一到两篇博客,即是对自己的督促,也是对知识的巩固!

这个题本质上还是借助了链表的概念,创造一个数组也就是创造一个链表来保存队伍的信息。
一开始我并没有想到能直接创造一个数组来实现,导致想得过于复杂了。
以后在学数据结构的时候也要多做总结和归纳,吸取里面宝贵的技巧,不能写了一题忘了一题。

到此这篇关于C语言围圈报数题目代码实现的文章就介绍到这了,更多相关C语言围圈报数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C++之eigen安装与测试方式

    C++之eigen安装与测试方式

    这篇文章主要介绍了C++之eigen安装与测试方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • C++实现发送邮件和附件功能

    C++实现发送邮件和附件功能

    这篇文章主要为大家详细介绍了C++实现发送邮件和附件功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-05-05
  • C++ 中IO流详解

    C++ 中IO流详解

    这篇文章主要介绍了C++ IO流的相关知识点,文中有详细的代码,希望可以帮助大家更好的理解和学习c++,感兴趣的朋友可以了解下
    2023-05-05
  • C++如何实现简易扫雷游戏

    C++如何实现简易扫雷游戏

    这篇文章主要为大家详细介绍了C++如何实现简易扫雷游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • C++线程安全容器stack和queue的使用详细介绍

    C++线程安全容器stack和queue的使用详细介绍

    stack是一种容器适配器,专门用在具有后进先出操作的上下文环境中,其删除只能从容器的一端进行 元素的插入与提取操作;队列是一种容器适配器,专门用于在FIFO上下文(先进先出)中操作,其中从容器一端插入元素,另一端提取元素
    2022-08-08
  • VC++ 自定义控件的建立及使用方法

    VC++ 自定义控件的建立及使用方法

    这篇文章主要介绍了VC++ 自定义控件的建立及使用方法的相关资料,十分的详细,需要的朋友可以参考下
    2015-06-06
  • Qt+FFMPEG实现循环解码详解

    Qt+FFMPEG实现循环解码详解

    这篇文章主要为大家详细介绍了如何利用Qt+FFMPEG实现循环解码功能,文中的示例代码讲解详细,对我们学习Qt有一定帮助,需要的可以参考一下
    2022-08-08
  • C语言数据结构之栈和队列的实现及应用

    C语言数据结构之栈和队列的实现及应用

    栈和队列是一种数据结构,只规定了性质,并没有规定实现方式。本文将以顺序结构实现栈,链表方式实现队列,感兴趣的小伙伴快跟随小编一起学习一下吧
    2022-08-08
  • C#和C++编程语言中的类浅析

    C#和C++编程语言中的类浅析

    在本篇文章里我们给大家分析了C#和C++编程语言中的类的相关知识点,正在学习的朋友们跟着操作下。
    2019-02-02
  • C++中sprintf使用的方法与printf的区别分析

    C++中sprintf使用的方法与printf的区别分析

    这篇文章主要介绍了C++中sprintf使用的方法与printf的区别,实例分析了sprintf与printf的具体用法及相关注意事项,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-01-01

最新评论