2 1 2 2 1 1 2 3 4
1 3HintFor the first case, Soda can use 1 yuan to buy a set of 2 souvenirs. For the second case, Soda can use 3 yuan to buy a souvenir.
1001 Souvenir 本题是一个简单的数学题. 如果套装优惠的话就尽量买套装, 否则单件买. 注意一下如果一直用套装的话可能在最后的零头不如单买好, 即(n mod m)?p<q .
#include<iostream> #include<cstdio> using namespace std; int main() { int t,n,m,p,q;//单价p元,套装q元,一个套装有m个纪念品,总共n个参赛者 scanf("%d",&t); while(t--) { scanf("%d%d%d%d",&n,&m,&p,&q); int price = 0; if(q/m<p)//如果套装优惠的话尽量买套装 { if((n%m)*p<q)//如果在买套装最后零头的处理不如单价买便宜 { price = (n/m)*q+(n%m)*p;//就在最后零头买单价 } else { price = (n/m+1)*q;//否则多买一个套装 } } else//否则直接单价买 { price = n*p; } printf("%d\n",price); } return 0; }
今天是BestCoder一周年纪念日. 比赛管理员Soda想要给每个参赛者准备一个纪念品. 商店里纪念品的单价是p 元, 同时也可以花q 元购买纪念品套装, 一个套装里有m 个纪念品. 今天总共有n 个参赛者, Soda想要知道最少需要花多少钱才可以给每个人都准备一个纪念品.
输入有多组数据. 第一行有一个整数T (1≤T≤105) , 表示测试数据组数. 然后对于每组数据: 一行包含4个整数n,m,p,q (1≤n,m,p,q≤104) .
对于每组数据输出最小花费.
2 1 2 2 1 1 2 3 4
1 3
对于第一组数据, Soda可以1元购买一个套装. 对于第二组数据, Soda可以直接花3元购买一个纪念品.
版权声明:本文为博主原创文章,未经博主允许不得转载。
HDU-5310-Souvenir(C++ && 简单数学题)
原文地址:http://blog.csdn.net/qq_16542775/article/details/47066695