C++编程实现随机产生一个0,1数组,0的数量要少于数组长度的一半
思路:在一个元素都是1的一维数组里面,让0随机替换掉少于一半的数
1:通过键盘获取数组的大小。
2:设置一个元素都是1的一维数组。
3:设置一个变量少于数组的一半
4:通过rang()函数产生随机数,令这些产生的随机数当作数组的下标,把这些下标的数更改为0
5:输出一个只有0,1的一维数组,且0的数量是数组长度的一半
int main()
{
int a = 0;
int b = 0;
int n = 0;
cout << "请输入数组大小:";
cin >> n;
b = n;
int chip[100];
int num = n - (n / 2 + 1);
for (int i = 0; i < n; i++) {
chip[i] = 1;
}
srand((int)time(NULL));
for (int i = 0; i < num; i++) {
int nu = (int)(rand() % (b - a)) + a;
chip[nu] = 0;
}
for (int i = 0; i < n; i++) {
cout << chip[i];
}
cout << endl;
注意:还需要添加头文件
#include <stdlib.h>
#include <time.h>
效果图: