c语言实现从一个数组中随机抽取一个元素

实现从一个数组中随机抽取一个元素,一直抽取完。。比如a[100]={0,1,.......99};有方法抽取出来嘛、?要求效率高点的。。。... 实现从一个数组中随机抽取一个元素,一直抽取完。。
比如a[100]={0,1,.......99};有方法抽取出来嘛、?要求效率高点的。。。
展开
 我来答
百度网友5472d36
推荐于2017-09-29 · TA获得超过132个赞
知道小有建树答主
回答量:79
采纳率:0%
帮助的人:94.2万
展开全部
随机产生一个数,然后每次将数组元素的最后一个数与这个数交换,并且数组的长度减1。代码如下:
#include<stdio.h>
#include<stdlib.h>
#define N 100

int main()
{
int a[N];
int i,t,tag;
for(i=0;i<N;i++)
a[i] = i;
tag = N-1;
while(tag)
{
i = rand()%tag;
t = a[i];
a[i] = a[tag];
a[tag] = t;
printf("%d ",t);
tag--;
}
return 0;
}
福泽佑之IN
2014-07-07 · TA获得超过2473个赞
知道小有建树答主
回答量:727
采纳率:0%
帮助的人:687万
展开全部
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

int main(void)
{
    int vis[100] = {0}, tot = 100;
    srand((int)time(0));
    for(;tot;)
    {
        int index = rand() % 100;
        if(!vis[index])
        {
            printf("%d ", index);
            vis[index] = 1;
            tot--;
        }
    }
    return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
真相很简单
2014-07-07 · TA获得超过643个赞
知道小有建树答主
回答量:539
采纳率:50%
帮助的人:410万
展开全部
int [] b = new int[100];
int t = 0, idx = 0, len = a.length;
for(int i=0;i<len;i++)
{
    idx = [rand()*(len-i)];
    b[i] = a[idx];
    
    t = a[idx];
    a[idx] = a[len - 1];
    a[len - 1] = t;
}
return b;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式