| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 5410 人关注过本帖
标题:(用指针做)有n个人围成一圈,顺序排好,从第一个人开始报数(从1到3报数) ...
只看楼主 加入收藏
krisdei
Rank: 1
等 级:新手上路
帖 子:30
专家分:0
注 册:2018-4-6
结帖率:50%
收藏
已结贴  问题点数:10 回复次数:8 
(用指针做)有n个人围成一圈,顺序排好,从第一个人开始报数(从1到3报数),凡提到的3的退出圈子,问最后留下的是原来的第几号的那位:
(用指针做)有n个人围成一圈,顺序排好,从第一个人开始报数(从1到3报数),凡提到的3的退出圈子,问最后留下的是原来的第几号的那位:大神指导
搜索更多相关主题的帖子: 围成一圈 顺序 一个人 报数 退出 
2018-04-06 10:24
李晨经纪人
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:6
帖 子:175
专家分:848
注 册:2018-2-14
收藏
得分:4 
就是把数组用指针表示吧。
程序代码:
#include<stdio.h>
int main(void)
{
    int i,n,*p,num,count=0;
    int a[100]={0};
    p=a;
    scanf("%d",&n);
    num=n;
    while(num!=1)
    {
        for(i=0;i<n;++i)
        {
            if(*(p+i)==0)
                count++;
            if(count==3)
            {
                num--;
                count=0;
                *(p+i)=1;
            }
        }
    }
    for(i=0;i<n;++i)
        if(*(p+i)==0)
            printf("剩下第%d位\n",i+1);
    return 0;
}
2018-04-06 17:55
童生
Rank: 6Rank: 6
等 级:侠之大者
威 望:8
帖 子:205
专家分:455
注 册:2018-3-7
收藏
得分:4 
这个算法是有问题的吧?13,23,43,。。。。都不是3的倍数....
2018-04-07 09:23
李晨经纪人
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:6
帖 子:175
专家分:848
注 册:2018-2-14
收藏
得分:0 
回复 3楼 童生
干嘛要是3的倍数
2018-04-07 10:21
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:4 
回复 3楼 童生
这个就是著名的经典约瑟夫环问题,围成一圈相当于一个环,可以理解~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2018-04-07 10:26
李晨经纪人
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:6
帖 子:175
专家分:848
注 册:2018-2-14
收藏
得分:0 
回复 3楼 童生
比如n=13
到a[12]时count=1 -> num!=1 -> 下一次遍历 a[0]时count=2 ,然后继续数啊。和是不是3的倍数有什么关系啊
2018-04-07 10:27
童生
Rank: 6Rank: 6
等 级:侠之大者
威 望:8
帖 子:205
专家分:455
注 册:2018-3-7
收藏
得分:0 
回复 6楼 李晨经纪人
(从1到3报数),

漏看了这几个字....
2018-04-07 11:43
krisdei
Rank: 1
等 级:新手上路
帖 子:30
专家分:0
注 册:2018-4-6
收藏
得分:0 
回复 2楼 李晨经纪人
谢谢了 作为大一生 还有很多不懂的地方 继续学习
2018-04-08 17:45
Sheryl
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2018-12-2
收藏
得分:0 
回复 2楼 李晨经纪人

如果要按顺序输出被退出的人呢,该怎么修改
2018-12-03 00:00
快速回复:(用指针做)有n个人围成一圈,顺序排好,从第一个人开始报数(从1到3 ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.136722 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved