C言语优化双色球自选步伐的小才略

原帖及讨论:http://bbs.bc-cn.net/dispbbs.asp?BoardID=5&ID=120387

我刚最先写双色球机选步伐都是像下面多么写

#include<math.h>
#include<stdlib.h>
#include<time.h>

main()
{
    int i ,j ,k;
    int num[6];

    srand((unsigned)time(NULL));

    for(i = 0;i < 6;i )
    {
        num[i] = random(33) 1;

        for(j = 0;j < i;j )
        {
            if(num[i] == num[j])
            {
                i--;
                j = 7;
            }
        }
    }
    num[5] = random(16) 1;
    for(i = 0;i < 6;i )
     printf("- ",num[i]);

    printf(" - ",num[5]);
    getch();
}

这种写法的好处是好想

然则要承认的是这种写法屈从很低(而且这个步伐仍是没有加号码巨细的排序)

要只输入多量号码组的时间或许并没有施展阐发出它的低效成果

然则在发生并输入大量这些号码的时间就会施展阐发出其低效性
为此我想到了一个更好的设备:

#include<math.h>
#include<stdlib.h>
#include<time.h>

main()
{
    int i ,j ,k;
    int num[6];

    srand((unsigned)time(NULL));

    num[0] = random(28) 1;
    for(i = 1;i < 6;i )
    {
        num[i] = num[i-1] random(28-num[i-1] i) 1;
    }

    num[5] = random(16) 1;
    for(i = 0;i < 6;i )
     printf("- ",num[i]);

    printf("- ",num[i]);
    getch();
}

各人可以很快的看出这个步伐要优于上一个步伐

固然多么屈从会很高 然则凑合做彩票软件的人来说会遇到一个成果

便是在对大量彩票号码组停止比较可否反复的比较 和 号码的定位 的时间却会很费事

以是我就想到一个经由议定对号码标号计数的设备来自选

#include<math.h>
#include<stdlib.h>
#include<time.h>
#include<graphics.h>

int Init();
int MakeForm();
int *(OutNum)();
unsigned long C(int a ,int b);
unsigned long A(int a ,int b);

unsigned long Form[29][6];
unsigned long Max;

int main()
{
    Init();
    MakeForm();
    while(getch() != 27) OutNum();
}

int Init() /* 施展阐发形式和随机函数初始化 用图形形式是为了能在一个屏幕中施展阐发更多的信息 */
{
    int gd = DETECT,gm = 0;

    initgraph(&gd ,&gm ,""); /* 图形形式初始化 */
    srand((unsigned)time(NULL)); /* 随机函数时间点初始化 */
    Max = C(6 ,33);
}

int MakeForm() /* 制订号码盘查表  在真正的运用中就可不用做输入了 */
{
    int i ,j;

    for(i = 1;i <= 28;i )
    {
        Form[i][0] = C(5,33-i);
        printf("=-->%-2ld\t",i ,Form[i][0]);
        Form[i][1] = C(4,32-i);
        printf("=-->%-2ld\t",i 1 ,Form[i][1]);
        Form[i][2] = C(3,31-i);
        printf("=-->%-2ld\t",i 2 ,Form[i][2]);
        Form[i][3] = C(2,30-i);
        printf("=-->%-2ld\t",i 3 ,Form[i][3]);
        Form[i][4] = 29-i;
        printf("=-->%-2ld\n",i 4 ,Form[i][4]);


Form[i][5] = 1;
    }
}


int *(OutNum)() /* 机选双色球号码 n为号码组的标号 */
{
    int i ,j;
    unsigned long n ,r=1;
    int num[6];

    n = ((unsigned long)rand()*rand())%Max;
    printf("%ld\n",n);

    for(i = 0 ,j = 0;j < 6;j )
     for(r = 1;i <= 28 j && r; )
     {
         if(n < Form[i][j])
         {
             num[j] = i j;
             printf("- ",num[j]);
             r = 0;
         }
         else
         {
            n -= Form[i][j];
            i ;
         }

    }
    num[6] = random(16) 1;
    printf(" -\n",num[6]);

    return num;
}

unsigned long C(int a ,int b)
{
    int i ,j;
    unsigned long na = 1 ,nb = 1;
    for(i = 0;i < a;i )
    {
        na *= (b-i);
        nb *= i 1;
    }
    return na/nb;
}

unsigned long A(int a ,int b)
{
    int i;
    unsigned long na = 1;
    for(i = 0;i < a;i )
    {
        na *= (b-i);
    }
    return na;
}


步伐中的谁人制表只在步伐的最先运转一次 并存储在Form中(我相信不会浪费很大内存)

这个步伐固然是机选步伐

然则这个设备却可用做号码的保管 运算 施展阐发 而且会施展阐发出更高效便利的一壁

在此过失其步伐停止书写



版权声明: 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始情由 、作者信息和本声明。否则将清查执法责任。

posted @ 2011-03-07 18:39  蓝色的天空III  阅读(185)  评论(0编辑  收藏  举报