Qt生成随机数的方法

1.生成随机数

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

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

  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. }  
        注意代码中使用的种子,这里没有用固定值来作为种子,是希望函数在每次调用(间隔大于1秒)时生成的随机数不一样。

2.生成不重复的随机数

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

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

猜你喜欢

转载自blog.csdn.net/noricky/article/details/80050922