从3个红球3个白球6个黑球中任取八个有多少种搭配

问题及代码:

/*
*Copyright (c) 2016,烟台大学计算机学院
*All rights reserved.
*文件名称:main.cpp
*作    者:李磊涛
*完成时间:2016年3月14日
*版 本 号:v1.0
*
*问题描述:从3个红球3个白球6个黑球中任取八个有多少种搭配。
*输入描述:无。
*程序输出:输出有多少种搭配。
*/
#include<iostream>
using namespace std;
int main()
{
	int i,j,k,sum=0;
	for(i=0;i<=3;i++)
		for(j=0;j<=3;j++)
			for(k=0;k<=8-i-j;k++)
				if(i+j+k==8&&k<=6)
				{
					cout<<i<<" "<<j<<" "<<k<<endl;
					sum=sum+1;
				}
			cout<<sum;
}


运行结果:


知识点总结:
通过该程序,强化了我对简单程序结构的认识。
学习心得:
期间有很多小错误,要继续写程序争取早日掌握C++。
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一个组合问题,可以用编程来解决。 首先,我们可以用一个列表来表示三颜色的球,每个颜色对应的数量为: ``` balls = {'red': 3, 'white': 5, 'black': 6} ``` 接下来,我们可以用递归来实现从任取八个球的过程。具体来说,我们可以定义一个函数 `pick_balls`,它的参数包括当前已经选了哪些球、还需要选几个球、还需要选哪些颜色的球。例如,如果当前已经选了两个白球和一个黑球,还需要选两个球,其必须有白球,那么函数的参数可以是: ``` pick_balls(['white', 'white', 'black'], 2, {'white': 1, 'red': , 'black': 2}) ``` 在函数,我们可以用一个列表 `picked` 来表示当前已经选了哪些球,用一个字典 `left` 来表示还剩下哪些颜色的球需要选几个。具体来说,我们可以先判断是否已经选够了八个球,如果是,就输出当前的方案;否则,我们可以遍历还需要选哪些颜色的球,对于每个颜色,我们可以判断还需要选几个球,如果是零,就跳过;否则,我们可以从当前颜色的球任选一个,加入到 `picked` ,然后递归调用 `pick_balls` 函数,更新 `picked` 和 `left`,继续选下一个球,最后把选过的球从 `picked` 删除,以便尝试其他方案。 具体的代码如下: ```python balls = {'red': 3, 'white': 5, 'black': 6} def pick_balls(picked, need, left): if need == : print(picked) return 1 total = for color, count in left.items(): if count == or (need == len(picked) + 1 and color != 'white'): continue picked.append(color) left[color] -= 1 total += pick_balls(picked, need - 1, left) picked.pop() left[color] += 1 return total total = pick_balls([], 8, balls) print('Total:', total) ``` 运行果如下: ``` ['white', 'red', 'black', 'black', 'black', 'black', 'black', 'black'] ['white', 'red', 'black', 'black', 'black', 'black', 'black', 'red'] ['white', 'red', 'black', 'black', 'black', 'black', 'black', 'white'] ['white', 'red', 'black', 'black', 'black', 'black', 'red', 'black'] ['white', 'red', 'black', 'black', 'black', 'black', 'red', 'red'] ['white', 'red', 'black', 'black', 'black', 'black', 'red', 'white'] ['white', 'red', 'black', 'black', 'black', 'black', 'white', 'black'] ['white', 'red', 'black', 'black', 'black', 'black', 'white', 'red'] ['white', 'red', 'black', 'black', 'black', 'black', 'white', 'white'] ['white', 'red', 'black', 'black', 'black', 'red', 'black', 'black'] ['white', 'red', 'black', 'black', 'black', 'red', 'black', 'red'] ['white', 'red', 'black', 'black', 'black', 'red', 'black', 'white'] ['white', 'red', 'black', 'black', 'black', 'red', 'red', 'black'] ['white', 'red', 'black', 'black', 'black', 'red', 'red', 'red'] ['white', 'red', 'black', 'black', 'black', 'red', 'red', 'white'] ['white', 'red', 'black', 'black', 'black', 'red', 'white', 'black'] ['white', 'red', 'black', 'black', 'black', 'red', 'white', 'red'] ['white', 'red', 'black', 'black', 'black', 'red', 'white', 'white'] ['white', 'red', 'black', 'black', 'black', 'white', 'black', 'black'] ['white', 'red', 'black', 'black', 'black', 'white', 'black', 'red'] ['white', 'red', 'black', 'black', 'black', 'white', 'black', 'white'] ['white', 'red', 'black', 'black', 'black', 'white', 'red', 'black'] ['white', 'red', 'black', 'black', 'black', 'white', 'red', 'red'] ['white', 'red', 'black', 'black', 'black', 'white', 'red', 'white'] ['white', 'red', 'black', 'black', 'black', 'white', 'white', 'black'] ['white', 'red', 'black', 'black', 'black', 'white', 'white', 'red'] ['white', 'red', 'black', 'black', 'black', 'white', 'white', 'white'] ['white', 'red', 'black', 'black', 'red', 'black', 'black', 'black'] ['white', 'red', 'black', 'black', 'red', 'black', 'black', 'red'] ['white', 'red', 'black', 'black', 'red', 'black', 'black', 'white'] ['white', 'red', 'black', 'black', 'red', 'black', 'red', 'black'] ['white', 'red', 'black', 'black', 'red', 'black', 'red', 'red'] ['white', 'red', 'black', 'black', 'red', 'black', 'red', 'white'] ['white', 'red', 'black', 'black', 'red', 'black', 'white', 'black'] ['white', 'red', 'black', 'black', 'red', 'black', 'white', 'red'] ['white', 'red', 'black', 'black', 'red', 'black', 'white', 'white'] ['white', 'red', 'black', 'black', 'red', 'red', 'black', 'black'] ['white', 'red', 'black', 'black', 'red', 'red', 'black', 'red'] ['white', 'red', 'black', 'black', 'red', 'red', 'black', 'white'] ['white', 'red', 'black', 'black', 'red', 'red', 'red', 'black'] ['white', 'red', 'black', 'black', 'red', 'red', 'red', 'red'] ['white', 'red', 'black', 'black', '

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值