本文实例讲述了C++抽奖程序实现方法。分享给大家供大家参考。具体实现方法如下:
一、int rand()可以生成从[0, 65536)之间均匀分布的随机数。
现要求实现:有30万员工,使用rand()写一个抽奖程序,抽出人100获奖。
#include <iostream> #include <set> using namespace std; typedef set<int> ISET; ISET GetPridePersonId(const int num, const int pride_num) { int id; ISET iset; while (1) { id = (int)((double)rand() / RAND_MAX * num) % (num - 1); if (iset.find(id) == iset.end()) { iset.insert(id); } if (iset.size() >= pride_num) { break; } } return iset; } void print(ISET &iset) { ISET::iterator iter; cout<<"item as :\n"; for (iter = iset.begin(); iter != iset.end(); ++ iter) { cout<<*iter<<"\n"; } } int main(int argc, char **argv) { const int total_person = 300000; const int total_pride_person = 100; ISET iset = GetPridePersonId(total_person, total_pride_person); print(iset); return 0; }
二、主要容易出错的地方:
①当rand()范围要求扩大的时候,浮点与整形数之间的强制转换问题。
int randId = (int)((double)rand() / RAND_MAX * num);
②STL中set的使用是否非常熟练?
希望本文所述对大家的C++程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#cainiaojc.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。