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