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>

效果图:

发布了28 篇原创文章 · 获赞 5 · 访问量 5808

猜你喜欢

转载自blog.csdn.net/weixin_41879980/article/details/89292827