Qt生成随机数

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默认递增排序,即使数列中包含相同的数。



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值