C语言实现约瑟夫环问题

#include<stdio.h>

#define N 100

void Joseph(int g[N], int t, int n, int k) {
    printf("Please enter the number of participants in the game:");
    scanf("%d", &t);
    printf("\nPlease enter the game start number:");
    scanf("%d", &n);
    printf("\nPlease enter death number:");
    scanf("%d", &k);
    int num = 0;    //记录报数;
    int death = 0;    //记录淘汰的人数;
    int i = 0;        //记录第几个被淘汰的玩家;
    while (death != (t - 1))
    {
        if (g[n] == 0){
            num++;
            if (num == k) {            
                g[n] = 1;
                death++;
                i++;
                num = 0;
                printf("The NO.%d player to die is g[%d]!\n", i, n+1);
            }
        }
        n++;
        if (n == t)
            n = 0;
    }
    for (int j = 0; j < sizeof(g)/sizeof(g[0]); j++)
    //sizeof是一种单目运算符用于计算数据在内存中所占用的空间大小
    //g:表示的是数组的地址;
    //g[0]:表示的是数组首元素的地址;
    //此时sizeof(g)/sizeof(g[0])=整个数组空间的大小;
    {
        if (g[j] == 0)
            printf("Congratulations to player g[%d] for being a survivor!\n", j);
    }
}
int main(){
    int game[N] = { 0 };
    int total = 0;    //参加游戏的人数;
    int n = 0;        //记录起始编号;
    int kill = 0;    //死亡编号;
    Joseph(game, total, n, kill);
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值