有趣的随机数

下面是随机产生1--10之间的不同值的一段程序:

以上程序的可能执行结果是
#include
#include
#include
main()
{
    int i, j, n;
    int a[10];
    srand((int)time(0));
    for(i = 0; i < 10; i ++) {
        a[i]  = 1 + (int) ((float)10 * rand() /(RAND_MAX + 1.0));
        if(i > 0) {
            for(j = 0; j < i; j++) {
                if(a[i] == a[j]) {
                    i--;
                    break;
                }
            }
        }
    }
    for(i = 0; i < 10; i++) {
        printf("a[%d] = %d\n", i, a[i]);
    }
}

sunjiangang@fan-laptop:~/program/c/dictionary1$ ./a.out
a[0] = 10
a[1] = 2
a[2] = 6
a[3] = 1
a[4] = 8
a[5] = 4
a[6] = 7
a[7] = 5
a[8] = 9
a[9] = 3
上面的程序是很容易想到的,但是rand()函数的调用次数是大于或等于10的,我还有一种方法同样也可以随机产生(1--10)不同值的10个数,但是这个方法中只须调用rand()函数10次,不多不少。大家可以做一下,与我的方法比对一下,也许我的另外的方法不如大家的。
下面是我改进后的算法,这样rand()只须执行10次就完全可以了,大大提高了效率,其实若利用上面的算法时,当要产生的随机数的范围不是10而是100,1000,或者更大时,这样的执行效率是很低的rand()执行的次数远远大于了n次
#include
#include
#include
main()
{
    int n = 10, i, a[10], b[10], num;
    for(i = 0; i < 10; i++) {
        a[i] = i+1;
    }
    srand((int)time(0));
    for(i = 0; i < 10; i++) {
//        a[i] = i + 1;
        num = (int)((float)n * rand() / (RAND_MAX + 1.0));
        b[i] = a[num];
        a[num] = a[n - 1];
        n--;
    }
    for(i = 0; i < 10; i++) {
        printf("b[%d] = %d\n", i, b[i]);
    }
}

<script>window._bd_share_config={"common":{"bdSnsKey":{},"bdText":"","bdMini":"2","bdMiniList":false,"bdPic":"","bdStyle":"0","bdSize":"16"},"share":{}};with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='http://bdimg.share.baidu.com/static/api/js/share.js?v=89860593.js?cdnversion='+~(-new Date()/36e5)];</script>
阅读(833) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~
评论热议
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值