面试题精选(70):100人民币问题
来源:互联网 发布:淘宝qs认证流程 编辑:程序博客网 时间:2024/04/29 13:08
题目描述:
用1元,2元,5元,10元,20元和50元的纸币组成100元,共有多少种情况。
要求输出总方案数和每种方案中各纸币的个数。
////////////////////////////4562种
代码:
背包解法:
#include <iostream>
using namespace std;
#define N 6
int w[N];
int number_used[N];
//bool is_used[N];
int countnum=0;
void init()
{
w[0] = 1;
w[1] = 2;
w[2] = 5;
w[3] = 10;
w[4] = 20;
w[5] = 50;
for (int i = 0; i < N; i++)
{
number_used[i] = 0;
}
}
void test(int start_index, int left_weight)
{
if (left_weight == 0)
{
for (int i = 0; i < N; i++)
{
if (number_used[i] > 0) cout << w[i] << "元: "<< number_used[i] <<"张 ";
}
cout << endl;
countnum++;
}
for (int i = start_index; i < N; i++)
{
if (left_weight >= w[i])
{
number_used[i]++;
test(i, left_weight - w[i]);
number_used[i]--;
}
}
}
int main()
{
init();
test(0, 100);
cout<<countnum<<endl;
system("pause");
return 0;
}
另外一种递归求总数解法:
const int v[6] = {1,2,5,10,20,50};
int f(int n, int w)
{
if(n<0) return 0;
if(n==0) return 1;
if(w<0) return 0;
return f(n, w-1) + f(n-v[w], w);
}
void main()
{
cout<<f(100,5)<<endl;
system("pause");
}
- 面试题精选(70):100人民币问题
- 面试题精选(一)
- 面试题精选(二)
- 程序员面试题精选100题(58)-八皇后问题
- 程序员面试题精选100题(58)-八皇后问题
- 程序员面试题精选100题(58)-八皇后问题
- 程序员面试题精选100题(58)-八皇后问题
- 程序员面试题精选100题(58)-八皇后问题
- [程序员面试题精选100题]58.八皇后问题
- 程序员面试题精选(23):跳台阶问题
- 面试题精选(83):二叉树相关的问题
- 面试题精选(87):两数组包含问题(来自微软面试题)
- 程序员面试题精选100题(完整版)博客地址
- 程序员面试题精选100题(56)-C/C++/C#面试题(4)
- 程序员面试题精选100题(52)-C++面试题(1)
- 程序员面试题精选100题(52)-C++面试题(1)
- 程序员面试题精选100题(52)-C++面试题(1)
- 程序员面试题精选100题(52)-C++面试题(1)
- Windows编程基础(API调用)
- 服装ERP手记(四)--DRP项目中软件系统架构的比较(转自51cto之技术论坛)
- Android学习——界面编程!
- s3c2410触摸屏驱动
- 在对话框程序中检测回车
- 面试题精选(70):100人民币问题
- 什么是SQL SERVER实例
- 安装带有水晶报表的项目
- 一道很有意思的JAVA题目
- listview 如何调整 行高
- linux ruby-rails 安装
- VBS中数组的动态改变、赋值、清除
- 读操作系统代码——分页设置的诊断
- Struts1读取图片,在JSP页面中显示