A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 黑马公公007 中级黑马   /  2015-10-12 19:53  /  898 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

耶稣有15个门徒,其中有一个就是出卖耶稣的叛徒,请用排除法找出这位叛徒:15人围坐一圈,从第一个开始报号:1,2,3,1,2,3……,凡是报到“3”就退出圈子,最后留在圈内的人就是出卖耶稣的叛徒,请找出它原来的序号。(C语言)



#include<stdio.h>
#include <stdlib.h>
//n表示最初有多少个人,m表示报数到多少的人离开,函数Joseph返回最后剩下的人的编号
int Joseph(int n,int m)
{  
    //int m=3;
    int count = n;   //count表示当前圈内剩下的人数
    int num=0;     //num表示当前报的数
    int i,j;       //i表示当前报数的人对应的下标
    int *a, remain;
    //动态申请连续的n个存储单元用来存放每个人的编号,将空间首地址赋值给a
    a = (int *)malloc(n*sizeof(int));
    for(i=0; i<n; i++)
        a = i+1; //a保存第i个人的编号
    i = 0; //从下标为0的人开始报数
    //printf("Delete In Order: ");
    while(count>1) //如果剩余人数大于1则循环
    {
         
        num++;
        if(num == m) //报数到m的人离开
        {
            //将下标为i的元素删除
            //printf("%d\t",a);
            for(j=i; j<count-1; j++)
                a[j] = a[j+1];
            count--; //当前剩余人数减1
            num = 0; //下一个人重新从1开始报数
            i-=1;         
        }
        i=(i+1)%count; //计算下一个要报数的人的下标
    }
    remain = a[0]; //最后只剩下一个人,将其编号赋值给remain
    return remain;
}
int main()
{
    int n,m;
    int i;
    printf("input n and m:n表示最初有多少个人,m表示报数到多少的人离开\n");
    while(scanf("%d%d",&n,&m)!=EOF)
    {
        //printf("%d\n",Joseph(n));
        printf("\nRemain: NO.%d\n",Joseph(n,m));
    }
    return 0;
}

个人觉得,这个题蛮有意思的,希望大家多多支持

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马