欢迎来到代码驿站!

C代码

当前位置:首页 > 软件编程 > C代码

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

时间:2022-07-11 10:14:44|栏目: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语言中动态内存分配malloc、calloc和realloc函数解析

本文标题:C语言围圈报数题目代码实现

本文地址:http://www.codeinn.net/misctech/207505.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有