数组元素 2作为数组的个体,数组中的每个元素都有 如下特征 它们的类型是相同的 每个元素用数组名加上括在方括号中的下 标表示。下标表示该元素在数组中的顺序, 下标以0为起始计数
6 数组元素 作为数组的个体,数组中的每个元素都有 如下特征: 它们的类型是相同的 每个元素用数组名加上括在方括号中的下 标表示。下标表示该元素在数组中的顺序, 下标以0为起始计数
模拟洗扑克牌 基本思路是:将54张扑克牌统一编号为: 0,1,2,5253,然后随机地从中一一抽取 张牌,并依次放起,形成新的序列。具 体要解决两个问题:如何存储54张扑克牌 以及在此基础上如何一一抽取 々随机抽牌算法 在0到53之间产生一个随机数r,将pk与 pk门交换
7 模拟洗扑克牌 基本思路是:将54张扑克牌统一编号为: 0,1,2,……,52,53,然后随机地从中一一抽取 一张牌,并依次放起,形成新的序列。具 体要解决两个问题:如何存储54张扑克牌 以及在此基础上如何一一抽取 随机抽牌算法 在0到53之间产生一个随机数r,将pk[0]与 pk[r]交换
类结构 #include <iostream h> #include <stdlib. h> int pklggchvanl {501,502, 101,102,103,104,105,106,107,108,109,110,111,112,113 201,202,203,204,205,206,207,208,209,210,211,212,213, 301,302,303,304,305,306,307,308,309,310,311,312,313, 401,402,403,404,405,406,407,408,409,410,411,412,4133 class pack t public void makepackonce o void Pack:: makepackonceo int temp, r; for(inti=0;i<53;i++)//洗一次牌 r= int(float(53 -i)* rand o/ RAND_MAX) +i; temp= pk [ [i]=pk[r]; pk[r]= temp; cout<<pk[订]<< //打印洗好的牌 cout < pk[i] < end1 //打印洗好的最后一张牌 8
8 类结构 #include <iostream.h> #include <stdlib.h> int pk[qqchyan1][] = { 501,502, 101,102,103,104,105,106,107,108,109,110,111,112,113, 201,202,203,204,205,206,207,208,209,210,211,212,213, 301,302,303,304,305,306,307,308,309,310,311,312,313, 401,402,403,404,405,406,407,408,409,410,411,412,413}; class Pack { public: void makePackOnce(); }; void Pack::makePackOnce() { int temp,r; for(int i = 0; i < 53; i ++) // 洗一次牌 { r= int(float(53 - i) * rand() / RAND_MAX) + i; temp = pk[i]; pk[i] = pk[r]; pk[r] = temp; cout << pk[i] << ","; // 打印洗好的牌 } cout << pk[i] << endl; // 打印洗好的最后一张牌 }
多次洗牌程序 void Pack:: makePackAny O Int temp,r, times; cout < nTimes for take the pack is: i Cin > times //输入拟洗牌次数 cout < endl for (int j=l; i<= times; 3++) //洗 times次牌 cout TIme j <<endl; for(inti=0;i<53;i++)//一次洗牌 Ir= int(float(53-i)* rand O/ RAND_MAX)+i; temp= pk[i]; pk[r]= temp cout < pk[i] cout < pk[i]<< endl; 9
9 多次洗牌程序 void Pack::makePackAny() { int temp,r,times; cout << "\nTimes for take the pack is:"; cin >> times; // 输入拟洗牌次数 cout << endl; for(int j =1; j <= times; j ++) // 洗times次牌 { cout << "Time: " << j <<endl; for(int i = 0; i < 53; i ++) //一次洗牌 {r= int(float(53 - i) * rand() / RAND_MAX) + i; temp = pk[i]; k[i] = pk[r]; pk[r] = temp; cout << pk[i] << ","; } cout << pk[i] << endl; } }
B动态地改变随机数序列起点 void Pack: makepackAny O int temp, r, times; cout < nTimes for take the pack is: cin >> times //′输入拟洗牌次数 cout < endT srand(time (null)) //用时间函数设置随机数序列的起点 for (int j=l;j<= times; j ++ // times次洗牌 for(inti=0;i<53;i++)//其中的一次洗牌 r= int(float(53-i)* rando/ RAND_MAX)+i; emp= pk[i]; pk[i]= pk[r]: pk[r] temp: cout<<pk[订]<<","; cout < pk[i] << endT 10
10 动态地改变随机数序列起点 void Pack::makePackAny() { int temp,r,times; cout << "\nTimes for take the pack is:"; cin >> times; // 输入拟洗牌次数 cout << endl; srand(time(NULL)); // 用时间函数设置随机数序列的起点 for(int j =1; j <= times; j ++) // times次洗牌 { for(int i = 0; i < 53; i ++) // 其中的一次洗牌 { r= int(float(53 - i) * rand() / RAND_MAX) + i; temp = pk[i]; pk[i] = pk[r]; pk[r] = temp; cout << pk[i] << ","; } cout << pk[i] << endl; } }