付款问题
来源:互联网 发布:算账软件 编辑:程序博客网 时间:2024/04/28 12:27
付款问题
Time Limit:1000MS Memory Limit:30000KB
Description
超市的自动柜员机(POS) 要找给顾客各种数值的现金,表面上看,这是一个很简单的任务,但交给机器办就不简单了。你作为一个
计算机专家,要求写一个程序来对付这个"简单"的问题。
你的自动柜员机有以下的币种:100元,50元,20元,10元,5元,2元,1元。你可以假设每种钱币的数量是无限的。现在有一笔交
易,需要找给客户m元,请你设计一个算法,使得找给顾客的钱币张数最少。
Input
第一行仅有一个整数n(0<n<=10000),表示有几组测试数据。
每组测试数据仅有一行,每行只有一个整数m(0<m<2000000000),表示需要找的钱币数。
(提示:对于大量的输出,请使用scanf,不要使用cin)
Output
每组测试数据输出一行,每行有7个整数(两两之间有一个空格,结尾不能有空格),表示100元,50元,20元,10元,5元,2元,1元
所需要的张数。
Sample Input
2
16
200
Sample Output
0 0 0 1 1 0 1
2 0 0 0 0 0 0
这道题用贪心算法即可解决,但贪心有时候并不能保证最优解。。。下面贴出代码吧:
#include <iostream>#include <cstring>using namespace std;int main(){ cin.sync_with_stdio(false);//解除绑定,优化读入 int a[] = {100,50,20,10,5,2,1}; int b[7]; int n; cin >> n; while(n--) { long long sum; cin >> sum; memset(b,0,sizeof(b)); b[0] = sum/a[0]; b[1] = (sum - b[0]*a[0])/a[1]; b[2] = (sum - b[0]*a[0] - b[1]*a[1])/a[2]; b[3] = (sum - b[0]*a[0] - b[1]*a[1] - b[2]*a[2])/a[3]; b[4] = (sum - b[0]*a[0] - b[1]*a[1] - b[2]*a[2] - b[3]*a[3])/a[4]; b[5] = (sum - b[0]*a[0] - b[1]*a[1] - b[2]*a[2] - b[3]*a[3] - b[4]*a[4])/a[5]; b[6] = (sum - b[0]*a[0] - b[1]*a[1] - b[2]*a[2] - b[3]*a[3] - b[4]*a[4] - b[5]*a[5])/a[6]; for(int i = 0; i < 7; ++i) { cout << b[i]; if(i != 6) { cout << " "; } } cout << endl; } return 0;}
0 0
- 付款问题
- 付款
- 关于GoDaddy支持支付宝付款的一些问题总结
- 网站上集成PayPal作为付款工具的问题
- 付款方式
- 付款方式
- 发票、付款
- 电脑付款
- 付款方式
- 付款操作
- 付款开始了付款了
- 付款流程的付款单
- 较难的动态规划问题——付款问题,面值任意,可找零
- 中国农业银行网上银行付款遇到的NetSign.cab被阻止的问题
- 解决贝宝不能接收国外收款和对国外付款的问题
- App Store开人民币付款先河 苹果中国本土化路上问题多
- 终于研究出如何设置新版paypal付款时汇率损失方的问题了
- 解决支付宝“创建交易异常,请重新创建后付款”的问题
- 原生javascript 简易实现放大镜效果
- 无法打开包括文件: “extensions/ExtensionExport.h”: No such file or directory
- 本地下载的软件包制作成本地repo源并使用apache发布
- 上下机消费时间+职责链模式
- RPC
- 付款问题
- xml文件中空格输入
- Ubuntu系统使用光盘作为apt-get源
- 视频相关学习笔记
- ajax详解
- HDU-5615-Jam's math problem
- 常用的 redis操作
- 关于我及各种链接
- python中主线程等待子线程完成的实现(join())