程序。
求一个程序。。
随机产生一个数组a[16],要求每个元素必须是1到8中的一个,且每个数字在数组a中只出现两次。。关于随机的问题我一直很疑惑,望大大们发段代码或算法指点一下。。谢谢。
------解决方案--------------------
产生一个1--8的随机数
判断出现次数,有2次就重新产生,没有就赋给元素
循环
------解决方案--------------------
不能使用rand函数么?
------解决方案--------------------
百度了下:
random函数,rand函数,这个函数也是一个随机函数,他可以产生从0到rand_max的随机数。
大家可以把以上的代码编译运行一下,发现他的确产生随机数了,但是你会发现,每次运行程序产生的随机数都是一样的,如过
你在程序里加上for循环,每次产生的数不一样,但是,如果再运行这个程序,它产生的数一样
那么如何写一个程序,让它每次运行时产生的随机数都不一样呢? 请看下面的例子:
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
int main(void)
{
int i;
time_t t;
srand((unsigned) time(&t));
printf("Ten random numbers from 0 to 99\\n\\n");
for(i=0; i<10; i++)
printf("%d\\n", rand() % 100);
return 0;
}
这时运行程序,会发现每次产生的随机数都不一样。
那么为什么第一个程序一样而第二个程序一样呢?
第二个程序用到了一个新的函数srand
这个函数是给随机数产生一个随机种子(seed),函数原型是srand( (unsigned)time( NULL ) );
time的值每时每刻都不同。所以种子不同,所以,产生的随机数也不同。
所以说,要想产生不同的随机数,在使用rand之前需要先调用srand
srand和rand函数都包含在stdlib.h的头文件里。
由于rand产生的随机数是从0到rand_max的,而rand_max是一个很大的数,那么如何产生从X~Y的数呢?
从X到Y,有Y-X+1个数,所以要产生从X到Y的数,只需要这样写:
k = rand() % (Y - X + 1) +X;
这样,就可以产生你想要的任何范围内的随机数了。
http://zhidao.baidu.com/question/39613912.html
自己也学习了
------解决方案--------------------
srand ( (unsigned) time (NULL) );
a=rand()%7 + 1; //产生1--8的随机数
------解决方案--------------------
好像就这样了,怎么还没有结贴
------解决方案--------------------
看看符不符合你的要求。
随机产生一个数组a[16],要求每个元素必须是1到8中的一个,且每个数字在数组a中只出现两次。。关于随机的问题我一直很疑惑,望大大们发段代码或算法指点一下。。谢谢。
------解决方案--------------------
产生一个1--8的随机数
判断出现次数,有2次就重新产生,没有就赋给元素
循环
------解决方案--------------------
不能使用rand函数么?
------解决方案--------------------
百度了下:
random函数,rand函数,这个函数也是一个随机函数,他可以产生从0到rand_max的随机数。
大家可以把以上的代码编译运行一下,发现他的确产生随机数了,但是你会发现,每次运行程序产生的随机数都是一样的,如过
你在程序里加上for循环,每次产生的数不一样,但是,如果再运行这个程序,它产生的数一样
那么如何写一个程序,让它每次运行时产生的随机数都不一样呢? 请看下面的例子:
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
int main(void)
{
int i;
time_t t;
srand((unsigned) time(&t));
printf("Ten random numbers from 0 to 99\\n\\n");
for(i=0; i<10; i++)
printf("%d\\n", rand() % 100);
return 0;
}
这时运行程序,会发现每次产生的随机数都不一样。
那么为什么第一个程序一样而第二个程序一样呢?
第二个程序用到了一个新的函数srand
这个函数是给随机数产生一个随机种子(seed),函数原型是srand( (unsigned)time( NULL ) );
time的值每时每刻都不同。所以种子不同,所以,产生的随机数也不同。
所以说,要想产生不同的随机数,在使用rand之前需要先调用srand
srand和rand函数都包含在stdlib.h的头文件里。
由于rand产生的随机数是从0到rand_max的,而rand_max是一个很大的数,那么如何产生从X~Y的数呢?
从X到Y,有Y-X+1个数,所以要产生从X到Y的数,只需要这样写:
k = rand() % (Y - X + 1) +X;
这样,就可以产生你想要的任何范围内的随机数了。
http://zhidao.baidu.com/question/39613912.html
自己也学习了
------解决方案--------------------
srand ( (unsigned) time (NULL) );
a=rand()%7 + 1; //产生1--8的随机数
------解决方案--------------------
好像就这样了,怎么还没有结贴
------解决方案--------------------
看看符不符合你的要求。
- C/C++ code
#include<stdio.h> #include<stdlib.h> #include<time.h> #define MAX 16 /*随机产生不相同的数,数字在1-n间*/ void generate(int a[], int n) { int i, j, tmp; int count[MAX] = {0}; srand(time(NULL)); i = 0; while(i < MAX) { tmp = rand() % n + 1; for(j = 0; j < i; j++) {//检查前i个数是否与新生成的数相同 if(a[j] == tmp) { count[a[j]]++; if(count[a[j]] >= 2) { break; } } } if(j==i) { a[i] = tmp; i++; } } } /*选择排序*/ void sort(int a[], int n) { int i, k, index, temp; for(k = 0; k < n - 1; k++) { index = k; for(i = k + 1; i < n; i++) { if(a[i] <a[index]) { index = i; } } if(index != k) { temp = a[index]; a[index] = a[k]; a[k] = temp; } } } /*输出数组元素*/ void output(int a[], int n) { int i; for(i = 0; i < n; i++) { if(i % 10 == 0) { printf("\n"); } printf("%2d ", a[i]); } } int main() { int a[MAX]; generate(a, 8); printf("\n The array is:"); output(a, MAX); sort(a, MAX); printf("\n After sorted:"); output(a, MAX); return 0; }
------解决方案--------------------
先让a[1..8]=1..8,a[9..16]=1..8
然后参考下面程序将a的顺序打乱
- C/C++ code
#include <stdio.h> #include <time.h> int d[6]; int i,n,a,b,t; int c,j; void main() { srand(time(NULL)); printf("shuffle 1..n demo\n"); for (n=1;n<=5;n++) {/* 测试1~5个元素 */ printf("_____n=%d_____\n",n); j=1; for (c=1;c<=n;c++) j=j*c;/* j为n! */ j*=n*2; for (c=1;c<=j;c++) {/* 测试n*2*n!次 */ for (i=1;i<=n;i++) d[i]=i;/* 填写1~n */ for (i=n;i>1;i--) {/* 打乱1~n */ a=i;b=rand()%i+1; if (a!=b) {t=d[a];d[a]=d[b];d[b]=t;} } printf("%04d:",c); for (i=1;i<=n;i++) printf("%d",d[i]); printf("\n"); } } }