目录
  • 围圈报数 题目
  • 解题步骤
    • 一.整体逻辑
    • 二.逻辑的实现
    • 三.代码的实现
  • 感悟

    围圈报数 题目

    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;
    }
    

    感悟

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

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

    声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。