| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1187 人关注过本帖
标题:关于加强版的约瑟夫环的问题 求指点
只看楼主 加入收藏
Poppy辉
Rank: 1
来 自:云南曲靖
等 级:新手上路
帖 子:33
专家分:4
注 册:2016-11-5
结帖率:66.67%
收藏
已结贴  问题点数:5 回复次数:4 
关于加强版的约瑟夫环的问题 求指点
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define n 100
int main()
{
    int i, j, k, count, number[n];
    int a[n];
    count =1;
    srand(time(NULL)+1);
    j=0;
   
    for( i=0; i<n; i++ )
    {   
        Begin:
        number[i] = rand()%791+10;
        for( j=0; j<i; j++ )
        {
            if( number[i]==number[j] )
            {
                goto Begin;
            }
        }                //此段代码为了求出100个不重复的随机整数
    }
   
    k = rand()%6+1; //先摇一次骰子
    for( i=1; i<=n; i++ )
    {
        
        if ( count<k && number[i-1]>0 )  //若还未达到骰子的点数就一直往下数
        {
            count++;
        }

        else if( count==k && number[i-1]>0) //达到骰子的点数后
        {                                    
            a[j] = number[i-1];                //将每次点数所对应的数值传给数组依次输出
            number[i-1] = 0;                //将之前对应点到的数值剔除
            j++;
            count = 1;                        //从一开始重新数
            k = rand()%6+1;                    //重新摇骰子
        }

        if( i==n )                            //当数值达到100时重头再来
        {
            i=0;
        }

        if( j==n )                        //点玩100人后结束
            break;
    }

    for( j=0; j<n; j++ )
    {
        printf("%d\t",a[j]);
    }


}
图片附件: 游客没有浏览图片的权限,请 登录注册
图片附件: 游客没有浏览图片的权限,请 登录注册
搜索更多相关主题的帖子: include 约瑟夫 number count 
2016-11-19 22:19
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:5 
j没有重置~//for( i=1,j=0; i<=n; i++ )

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2016-11-19 22:44
Poppy辉
Rank: 1
来 自:云南曲靖
等 级:新手上路
帖 子:33
专家分:4
注 册:2016-11-5
收藏
得分:0 
回复 2楼 九转星河
我靠,真是这样哇,真是厉害。 麻烦你能解释一下嘛。 为何需要重置j
2016-11-19 22:52
Poppy辉
Rank: 1
来 自:云南曲靖
等 级:新手上路
帖 子:33
专家分:4
注 册:2016-11-5
收藏
得分:0 
回复 2楼 九转星河
你是一下子就知道错误的地方了吗? 还有就是我的想法是,我觉得j是否重置对结果没影响的, 但是为何会有这么大的差别。
2016-11-19 22:56
Poppy辉
Rank: 1
来 自:云南曲靖
等 级:新手上路
帖 子:33
专家分:4
注 册:2016-11-5
收藏
得分:0 
回复 2楼 九转星河
好的  我懂了 之前的j被用过  我傻乎乎的以为在for里面的j只是个局部变量 不影响后续使用。
十分感谢,我调试了1个多小时的程序 你一下就看出来了 厉害。
2016-11-19 23:15
快速回复:关于加强版的约瑟夫环的问题 求指点
数据加载中...
 
   



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

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