c++ rand函数
调用rand()系统函数随机生成10个0—100的整数存放到数组中,然后将这些数组元素按从小到大要求排序,最后输出。(提示:应设置不同的“种子”)...
调用rand()系统函数随机生成10个0—100的整数存放到数组中,然后将这些数组元素按从小到大要求排序,最后输出。(提示:应设置不同的“种子”)
展开
展开全部
#include<time.h>
#include<iostream>
using namespace std;
void main()
{
int numArray[10];
for (int i=0; i < 10; i++)
{
srand((int)time(NULL));
numArray[i] = rand()%100;
// 这里为了使产生的种子不一样,睡眠1秒钟
Sleep(1000);
}
// 10秒后开始排序,所以程序执行的时候,你需要等待10秒
for (int i= 0; i < 10; i++)
{
for (int j = 0; j < 10-i -1;j++)
{
if (numArray[j] > numArray[j+1])
{
int tmp = numArray[j];
numArray[j] = numArray[j + 1];
numArray[j+ 1] = tmp;
}
}
}
// 输出
for (int i =0; i < 10; i++)
{
cout << numArray[i] << " ";
}
cout << endl;
}
运行结果:
展开全部
设了种子之后应该不会每次第一个数相同,可能你前后srand间隔太短,导致种子一样。
产生1到N随机数大可以1+rand()%N。
少用goto语句,不利于程序的结构化
产生1到N随机数大可以1+rand()%N。
少用goto语句,不利于程序的结构化
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<iostream>
#include<algorithm>
#include<stdlib.h>
using namespace std;
int main()
{
int a[10],n=10;
while(n)
{
a[10-n]=rand()%101;
n--;
}
sort(a,a+10);
n=10;
while(n)
{
cout<<a[10-n]<<endl;
n--;
}
}
#include<algorithm>
#include<stdlib.h>
using namespace std;
int main()
{
int a[10],n=10;
while(n)
{
a[10-n]=rand()%101;
n--;
}
sort(a,a+10);
n=10;
while(n)
{
cout<<a[10-n]<<endl;
n--;
}
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询