java 从0-16这17个数字中随机取出100个数,要求其中数字2出现4次,数字5出现7次,数字7出现5次,其他任意
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java 从0-16这17个数字中随机取出100个数,要求其中数字2出现4次,数字5出现7次,数字7出现5次,其他任意相关的知识,希望对你有一定的参考价值。
求思路。。。
先声明一个容量为100的数组。1、循环取得4个100以内不重复的随机数,作为数组下标;
2、判断数组中第1步取得的下标中是否有值,如果没有,就将该处设为2;有则执行第1步;
3、按第1、2步,设置数字5和数字7的位置。
4、循环100次,生成任意0~16之间的数字,如果生成的随机数是2、5或者7,重新生成;
5、判断当前循环处的数组位置是否有值,没有则将该处设置为生成的随机数,有则重新执行第4步。
over 参考技术A 1.产生随机数,2、5、7个字出现的次数进行个字累加
2.如果出现次数达到上限,产生的随机数抛弃,只保留符合的随机数!
3.将产生的随机数直接显示或存放到数组及集合中!都OK!追问
第二步 将达到次数上限的数字抛弃的方法 具体怎么做啊 ?
追答如果存在当前值出现次数达到上限,不向数组或集合中插值就OK了!然后接着循环知道数组或者集合长度到100!
参考技术B 同意 wcy981123的说法 参考技术C 1本回答被提问者采纳 参考技术D 这个比较麻烦如果需要我可以给你代码,邮箱,帮你写一个C语言程序:从N个数中随机取出100个不同的数
/**你题目中的N个数至少得大于100吧.下面的程序N个数是随机生成你的N个数是??? 同时这个程序有错误的话请告诉我.
*/
/*
*从N个数中随机取出100个不同的数
*@author:banxi1988
*/
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
int main(void)
int numbers[4096];
int nums[100];
int num;
int count=0;
int i = 0;
int j = 0;
int flag = 0;
int index= 0;
srand((unsigned)time(NULL));
/**随机生成0到8192的数放到数组numbers当中*/
for(i = 0; i < 4096; i++)
numbers[i] = rand()%8192;
//for:
/**从numbers数组当中的数中随机取100个不同的数*/
for(i = 0; i< 100;i++)
flag = 1;
do
index = rand()%4096;
num = numbers[index];
for(j = 0; j < count; j++)
if(num==nums[j])
flag = 0;
break;
//:if
//:for
while(flag==0);
nums[count++]=num;
///for:
printf("从0到8192中产生的100个随机的不相同的数如下:\n");
for(i = 0; i< 100;i++)
if(i%10==0)putchar('\n');
printf("%5d",nums[i]);
putchar('\n');
return 0;
/*运行结果如下:
从0到8192中产生的100个随机的不相同的数如下:
4206 7853 1327 4541 398 754 5374 5259 258 4411
2069 4161 5186 5419 1746 1531 1957 7334 157 1693
5140 6087 1879 6489 2659 1210 102 2302 1522 7118
603 1711 1322 4489 6386 2732 3418 2203 4000 1309
4269 4382 2389 7617 5899 5054 818 4337 1247 5513
7369 2756 2956 7529 6623 6744 5229 4684 7251 2584
5868 3451 1570 4214 1106 1487 4682 5848 4730 3291
6084 7570 602 2128 2447 1741 714 7384 5965 2182
439 5286 2605 6820 6221 6646 1348 3899 3016 4971
2381 2410 1126 1984 1633 2395 5670 1890 5346 2713
**/
//:main 参考技术A 随机取数 关键用到2个函数srand和rand
srand(time(NULL))是让你取到的数每次不一样因为用到了time函数,时间每秒都是不一样的
rand()就是去随机数啦
你可以把N个数存到1个数组里,然后随机100个下标志就OK了 参考技术B #include<stdlib.h>
#include<time.h>
#include<stdio.h>
void main()
int i,k,range,n,a[100];
int min,max,flag=0;
long t;
double j;
min=50;
max=500;
range=max-min;
srand((unsigned)time(&t)); /* 首先给srand()提供一个种子,它是一个unsigned int类型,其取值范围从0~65535;*/
do for(i=0;i<100;i++)
n=rand(); /*调用rand(),它会根据提供给srand()的种子值返回一个随机数(在0到32767之间)
根据需要多次调用rand(),从而不间断地得到新的随机数;*/
j=((double)n/(double)RAND_MAX); /*把随机数除以RAND_MAX,从而产生一个在0到1之间的校正值;*/
n=(int)(j*(double)range); /*把校正值乘以所需要的范围值(即500-50)从而产生一个在0到43之间的值*/
n+=min; /*把该值和所要求的最小值相加,从而使该值最终落在正确的取值范围----1到44之间。*/
a[i]=n;
for(i=0;i<99;i++) /* 判断这100个数是否重复,如果是,再生成一次,直到各不相同为止,也可以不要这段,呵呵*/
for(k=i+1;k<100;k++)
if(a[i]==a[k]) flag=1;flag=0;
while(flag);
printf("The random number is:\n"); /*产生100个50—500个随机数,并且排成10行10列*/
for(i=0;i<100;i++)
printf("%d ",a[i]);
if((i+1)%10==0) printf("\n");
看看这个,转别人的!
以上是关于java 从0-16这17个数字中随机取出100个数,要求其中数字2出现4次,数字5出现7次,数字7出现5次,其他任意的主要内容,如果未能解决你的问题,请参考以下文章
JAVA怎样随机生成10W个数字, 要求: 10W个数字总等于50W而且每个数字最小1最大100, 求代码及思路
java 从几十万条数据的list集合中随机取出1000个元素重新生成集合?
用java实现取1-100之间的99个不重复的随机数 然后输出没有被取出的数字