#include <stdio.h>
 
int main()
{
    // 假设k=3为报到计数单位量
    int i,k,m,n,num[50],*p;
    printf("输入人的数量:n=");
    scanf("%d",&n);
    p=num;
     
    for(i=0;i<n;i++)
        *(p+i)=i+1;//以1至n为序给每个人编号
    i=0;//i为每次循环时计数变量
    k=0;//k为按1,2,3报数时的计数变量
    m=0;//m为退出人数
    while (m<n-1)//当退出人数比n-1少时执行循环体
    {
        if(*(p+i)!=0) k++;
        if (k==3)
        {
            printf("出局人序号:%d\n",*(p+i));
         *(p+i)=0;//将退出的人的编号置为0
        k=0;//k报到3后,重置为0
        m++;//退出的人数+1
        }
        i++;
        if (i==n) i=0;//报数到尾后,i恢复为0
    }
    while (*p==0) p++;//如果p所指向的值等于0.那么就执行p++让它指向下一个元素,直到不为0.
    printf("最后留下的人的编号是:%d\n",*p);//经过上面的循环后,*p的指向的编号就是最后留下的人
     
    return 1;
}