【C语言简单题】有n个人围成一圈,顺序排号。从第1个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位

目录

1.思路

1用个标志flag=1 ++  每次flag==3 就退出一个人,flag置零

2.效果图


1.思路

1用个标志flag=1 ++  每次flag==3 就退出一个人,flag置零

2 需要注意的是把清清零,只是赋值为0 而不是删掉了,遍历数组的时候依旧会过一遍

#include<stdio.h>
#include<stdlib.h>

int main ()
{
	int n,i,flag=0;
	puts("请输入人数:");
	scanf("%d",&n);
	//按顺序排号人数 
	int *arr=(int*)malloc(sizeof(int)*n);
	if(arr==NULL)
	{
		perror("malloc");
		return 1;
	}
	
	for(i=0;i<n;i++)
	{
		arr[i]=i+1;
	}
	
	//保留当前原始人数 
	int count = n;
	
	//人数大于1的时候进去,人数等于1了就不用进去了 
	while(n>1)
	{
		for(i = 0 ; i < count ; i++)
		{
			if(arr[i]!=0)
			{
				flag++;
				//位置上的人没有被清零就报数
				//报数到三就被清零,flag重置,人数减一 
				// 
				if(flag==3)
				{
					flag=0;
					arr[i]=0;
					n--;
				}
			}
		}		
	} 
	 
	 //输出剩下的一个人 
	 for(i=0;i<count;i++)
	 {
	 	if(arr[i])
	 	{
	 		printf("最后剩下的人是:%d\n",arr[i]);
		}
	  } 
	  
	  //释放内存
	  free(arr);
	  arr=NULL; 
	return 0;
}

2.效果图

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值