标题:双色球打表去重复
只看楼主
ehszt
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:40
帖 子:1728
专家分:3216
注 册:2015-12-2
结帖率:100%
已结贴  问题点数:20 回复次数:3 
双色球打表去重复
突然觉得以前的双色球程序可以优化一下
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
int a[31]={0};
int redball()
{
    int m=rand()%31+1;
    if(a[m]==0)a[m]=1;
    while(a[m]!=0)     //生成不重复的数
    {
        m=rand()%31+1;
    }
    a[m]=1;
    return m;
}

int cmp(const void *a,const void *b)  //快排
{
    return *(int *)a-*(int*)b;
}

int main()
{
       int b[7]={0};
    srand((unsigned)time(0));
    for(int i=0;i<7;i++)
    {
        b[i]=redball();
    }
    qsort(b,7,sizeof(int),cmp);  //快排函数
    printf("7个红球号码分别为:\n");
    for(int i=0;i<7;i++)
    {
        printf("%d ",b[i]);
    }
    printf("\n1个蓝球号码为:\n%d",rand()%16+1);
    return 0;
}

[此贴子已经被作者于2018-3-31 17:56编辑过]

搜索更多相关主题的帖子: 双色球 int rand return printf 
2018-03-31 17:30
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
得分:10 
去重方法这个有比较完备的技术,可以通过"洗牌交换",数组块移动删除元素,之类的,当然这样打表效率也很高~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2018-03-31 17:44
ehszt
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:40
帖 子:1728
专家分:3216
注 册:2015-12-2
得分:0 
你说的那两种都没听过,不知道能不能讲讲?
2018-03-31 17:59
童生
Rank: 6Rank: 6
等 级:侠之大者
威 望:8
帖 子:205
专家分:455
注 册:2018-3-7
得分:10 
int b[33]={1,2,3,.....33};

for()
{
int a = rand()%33;
int c = rand()%33;

b[a] <=> b[c];
}
2018-03-31 18:17



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-485699-1-1.html




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

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