m0_62508191 2021-10-01 04:00 采纳率: 75%
浏览 110

25人围坐成圆圈,先从任意一人出发用1到25顺时针依次编号

25人围坐成圆圈,先从任意一人出发用1到25顺时针依次编号,然后从1号开始顺时针报数(1、2、3、……),凡报5的倍数者出圈,剩下者继续报数,求出最后出圈者的编号。
#include<stdio.h>
Void main() {int a[26], j, n, count; for(j=1;j<=25;j++) a[j]=j; j=1;count=0;n= 0 ; do {if(a[j]!=0) {n++; if(n%5= =0) { a[j]=0 ; if(count= =24) printf(“%d\n”, j); count++; } } j++; if(j>25) j=1; } while( count<25 );}跪求详细解释

  • 写回答

1条回答 默认 最新

  • m0_54204465 2023-01-30 15:50
    关注

    这段代码是实现一个输出最后出圈者编号的模拟程序。它首先通过循环为每一个人赋编号1到25。然后从编号为1的人开始顺时针报数,当报数为5的倍数时,则该人出圈,编号设置为0。当出圈人数为25时,输出最后一个出圈者的编号。

    评论

报告相同问题?

问题事件

  • 创建了问题 10月1日