【C/C++】随机数的生成

匿名 (未验证) 提交于 2019-12-02 23:52:01

 1 #include<stdio.h>  2 #include<stdlib.h>  3 #include<time.h>  4 int main()  5 {  6     srand((unsigned int)time(0));///以系统流逝时间为随机数发生器种子  7     for(int i=0;i<10;i++)  8     {  9         int n=rand()%(50-25)+25; ///产生25-50间的随机整数,rand%(b-a)+a即产生[a,b)范围内的随机整数 10         double d=rand()/(double)RAND_MAX; ///产生0-1的随机小数 11         printf("%d  %f\n",n,d); 12     } 13     puts(""); 14     printf("rand()函数可产生随机数的范围:0―%d\n",RAND_MAX); 15     return 0; 16 }

 1 #include<random>  2 #include<time.h>  3 #include<bits/stdc++.h>  4 using namespace std;  5 int main()  6 {  7     mt19937 mt_rand(chrono::high_resolution_clock::now().time_since_epoch().count());///随机种子  8     ///或用:mt19937 mt_rand(time(0));  9     for(int i=0;i<10;i++) 10     { 11         int n=mt_rand()%(1000-25)+25; ///产生25-1000间的随机整数 12         printf("%d\n",n); 13     } 14     return 0; 15 }

 1 #include <iostream>  2 #include <random>  3 using namespace std;  4   5 int main()  6 {  7     mt19937 rng;  8     rng.seed(random_device()());//初始化随机种子  9  10     uniform_int_distribution<int> int_dist(1,100);//创建一个均匀分布,等概率(随机)生成[1, 100]区间的整形数字; 11     uniform_real_distribution<double> real_dist(-1, 1);//创建一个均匀分布,(等概率)随机生成在(-1, 1)之间的小数; 12  13     for(int i=0;i<10;i++){ 14         cout << int_dist(rng) << ' '; 15         cout << real_dist(rng) << endl; 16     } 17     return 0; 18 }

来源: https://www.cnblogs.com/HOLLAY/p/11291799.html

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!