芭蕉树上第十九根芭蕉-- 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/qq_34327821/article/details/82724979