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 }