一道微软笔试题: 4个袋子,15个球,每个袋子至少放一个球,而且袋子中的球数量不能重复,有多少种方式
来源:互联网 发布:程序员好找对象吗 编辑:程序博客网 时间:2024/06/02 23:39
//一道微软笔试题
/************************************************************************/
/* 4个袋子,15个球,每个袋子至少放一个球,而且袋子中的球数量不能重复,有多少种方式
答:转化为问题 x1 + x2 + x3 + x4 = 15,
x1, x2, x3, x4 >= 1,
x4> x3 > x2 > x1.
(x1, x2, x3, x4) 一共有多少解。
设x2 = x1 + y1, x3 = x1 + y2, x4 = x1 + y3.
=>
x1 + x2 + x3 + x4 = 15
4 * x1 = 15 - (y1 + y2 + y3)
y1, y2, y3 >= 1,
y3 > y2 > y1.
=>
x1可以取值:x1 = 1, x1 = 2, 此时
1) x1 = 1时,
y1 + y2 + y3 = 11
y1, y2, y3 >= 1,
y3 > y2 > y1.
2) x1 = 2时
y1 + y2 + y3 = 7
y1, y2, y3 >= 1,
y3 > y2 > y1.
此时把一个问题分解为两个递归的子问题了。
如果记f(len, sum) 表示x[0] , x[1], ..., x[len - 1] 的和为sum且满足x[i] >= 1, x[i+ 1] > x[i]的解的个数
则f(len, sum) = f(len - 1, sum - len) + f(len -1, sum - 2*len) + ...+f(len - k, sum - k * len), sum - k * len >= (1 +2 + 3 +...+ len - 1)
*/
/************************************************************************/
/* 4个袋子,15个球,每个袋子至少放一个球,而且袋子中的球数量不能重复,有多少种方式
答:转化为问题 x1 + x2 + x3 + x4 = 15,
x1, x2, x3, x4 >= 1,
x4> x3 > x2 > x1.
(x1, x2, x3, x4) 一共有多少解。
设x2 = x1 + y1, x3 = x1 + y2, x4 = x1 + y3.
=>
x1 + x2 + x3 + x4 = 15
4 * x1 = 15 - (y1 + y2 + y3)
y1, y2, y3 >= 1,
y3 > y2 > y1.
=>
x1可以取值:x1 = 1, x1 = 2, 此时
1) x1 = 1时,
y1 + y2 + y3 = 11
y1, y2, y3 >= 1,
y3 > y2 > y1.
2) x1 = 2时
y1 + y2 + y3 = 7
y1, y2, y3 >= 1,
y3 > y2 > y1.
此时把一个问题分解为两个递归的子问题了。
如果记f(len, sum) 表示x[0] , x[1], ..., x[len - 1] 的和为sum且满足x[i] >= 1, x[i+ 1] > x[i]的解的个数
则f(len, sum) = f(len - 1, sum - len) + f(len -1, sum - 2*len) + ...+f(len - k, sum - k * len), sum - k * len >= (1 +2 + 3 +...+ len - 1)
*/
/************************************************************************/
int foo(int iLen, int sum){if(iLen == 1)return 1;int iRet = 0;int iTemp = iLen * (iLen - 1) / 2;int i = 1;while((sum -= iLen) >= iTemp)iRet += foo(iLen - 1, sum);return iRet;}int main(){/************************************************************************//* x1 + x2 + x3 + x4 = 15(1, 2, 3, 9)(1, 2, 4, 8)(1, 2, 5, 7) (1, 3, 4, 7) (1, 3, 5, 6)(2, 3, 4, 6) *//************************************************************************/cout << foo(4, 15) << endl;return 0;}
- 一道微软笔试题: 4个袋子,15个球,每个袋子至少放一个球,而且袋子中的球数量不能重复,有多少种方式
- 【1508】袋子里有多少个球(一般情况)
- 网易笔试题:幸运的袋子
- 网易笔试编程题-幸运的袋子
- 同放在袋子里
- 2017网易内推笔试题---幸运的袋子
- dfs+避免重复-幸运的袋子(网易题)
- 【其他】【RQNOJ】三个袋子
- 【数论】三个袋子
- 人生的四个袋子
- 建立词袋子模型
- RQNOJ85 三个袋子 题解、、
- 幸运的袋子
- 幸运的袋子
- 幸运的袋子
- 幸运的袋子---递归
- 幸运的袋子
- 幸运的袋子
- [Expression Blend 4] [SketchFlow系列] Chapter 3 瞭解SketchFlow Map (下)
- 一个好的程序员应该具备的能力(这也是面试时考察求职者的能力)
- sourcegrid合并单元格查询绑定数据
- 移动开发者大会.html5。Android。ios。wp联盟
- JS获取本周、本季度、本月、上月的开端日期、停止日期、某年某月有多少天
- 一道微软笔试题: 4个袋子,15个球,每个袋子至少放一个球,而且袋子中的球数量不能重复,有多少种方式
- 如果你懂,请不要只看到他的笑,你要看到他心底的泪
- Yahoo! S4:分布式流计算平台
- matlab中图像采集工具箱的应用
- IE6 BUG大全
- 写一个好的程序(面试及笔试中程序设计题要考察的内容)
- 英语练习93 Australia
- [Windows 8] 談 Metro UI 以及 Expression Blend 的未來
- Android 底部弹出提示窗口覆盖MENU