Qt生成随机数

这篇博客介绍了在Qt环境中如何生成随机数。通过qsrand设置种子,qrand生成随机数,通常qsrand未设置时默认种子为1。文章展示了生成[0,9]之间10个随机数的代码,并探讨了生成不重复随机数和升序排列随机数的方法,涉及到列表操作和排序算法。" 89068987,8412161,Android Studio:解决可视化界面无法显示的问题,"['Android开发', 'Android Studio', '问题解决', '界面显示', 'Gradle']
摘要由CSDN通过智能技术生成

1.生成随机数

        生成随机数主要用到了函数qsrand和qrand,这两个函数在#include <QtGlobal>中,qsrand用来设置一个种子,该种子为qrand生成随机数的起始值。比如说qsrand(10),设置10为种子,那么qrand生成的随机数就在[10,32767]之间。而如果在qrand()前没有调用过qsrand(),那么qrand()就会自动调用qsrand(1),即系统默认将1作为随机数的起始值。使用相同的种子生成的随机数一样。

       下列代码生成了[0,9]之间的10个随机数。

[cpp]  view plain  copy
  1. void generateRandomNumber()  
  2. {  
  3.     qsrand(QTime(0,0,0).secsTo(QTime::currentTime()));  
  4.     for(int i=0; i<10; i++)  
  5.     {  
  6.         int test =qrand()%10;  
  7.         qDebug()<<test;  
  8.     }  
  9. }</span>  
         注意代码中使用的种子,这里没有用固定值来作为种子,是希望函数在每次调用(间隔大于1秒)时生成的随机数不一样。

2.生成不重复的随机数

        这个没有特别好的方法,需要自己手动计算,代码如下。

[cpp]  view plain  copy
  1. void generateUniqueRandomNumber()  
  2. {  
  3.     int i,j;  
  4.     QList<int> numbersList;  
  5.     qsrand(QTime(0,0,0).secsTo(QTime::currentTime()));  
  6.     for(i=0;i<10;i++)  
  7.     {  
  8.         numbersList.append(qrand()%10);  
  9.         bool flag=true;  
  10.         while(flag)  
  11.         {  
  12.             for(j=0;j<i;j++)  
  13.             {  
  14.                 if(numbersList[i]==numbersList[j])  
  15.                 {  
  16.                     break;  
  17.                 }  
  18.             }  
  19.             if(j<i)  
  20.             {  
  21.                 numbersList[i]=rand()%10;  
  22.             }  
  23.             if(j==i)  
  24.             {  
  25.                 flag=!flag;  
  26.             }  
  27.         }  
  28.     }  
  29.     for(i=0;i<10;i++)  
  30.     {  
  31.         qDebug()<<numbersList[i];  
  32.     }  
  33. }  
3.生成递增的随机数
        就是在随机数生成后进行排序,Qt提供了一个非常好用的排序函数qSort,详细的用法可参考Qt帮助。

[cpp]  view plain  copy
  1. void generateAscendRandomNumber()  
  2. {  
  3.     int i;  
  4.     QList<int> numbersList;  
  5.     qsrand(QTime(0,0,0).secsTo(QTime::currentTime()));  
  6.     for(i=0;i<10;i++)  
  7.     {  
  8.         numbersList.append(qrand()%10);  
  9.     }  
  10.     qSort(numbersList.begin(),numbersList.end());  
  11.     for(i=0;i<10;i++)  
  12.     {  
  13.         qDebug()<<numbersList[i];  
  14.     }  
  15. }  
        输出结果如下所示,可以看出qSort默认递增排序,即使数列中包含相同的数。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值