题目描述
P老师需要去商店买n支铅笔作为小朋友们参加NOIP的礼物。她发现商店一共有 3种包装的铅笔,不同包装内的铅笔数量有可能不同,价格也有可能不同。为了公平起 见,P老师决定只买同一种包装的铅笔。
商店不允许将铅笔的包装拆开,因此P老师可能需要购买超过n支铅笔才够给小朋 友们发礼物。
现在P老师想知道,在商店每种包装的数量都足够的情况下,要买够至少n支铅笔最少需要花费多少钱。
输入输出格式
输入格式:
第一行包含一个正整数n,表示需要的铅笔数量。
接下来三行,每行用2个正整数描述一种包装的铅笔:其中第11个整数表示这种 包装内铅笔的数量,第2个整数表示这种包装的价格。
保证所有的7个数都是不超过10000的正整数。
输出格式:
1个整数,表示P老师最少需要花费的钱
把题目加进来了,因为不想解释,这题目看的头好痛
#include
int main()
{
int n , a1 , b1 , a2 , b2 , a3 , b3 , a , b , c , z ;
scanf("%d" , &n) ;
scanf("%d%d" , &a1 , &b1) ;
scanf("%d%d" , &a2 , &b2) ;
scanf("%d%d" , &a3 , &b3) ;
a = n / a1 ;//最少需要多少盒笔
if(( n % a1 ) == 0){
a = a * b1 ;//恰好整数盒笔,直接算价格
}else{
a = ( a + 1 ) * b1 ;//不是整数盒笔,多出来几支笔没有买,在此基础上多买一整盒笔,再算价格
}
//以下同理
b = n / a2 ;
if(( n % a2 )== 0){
b = b * b2 ;
}else{
b = (b + 1) * b2 ;
}
c = n / a3 ;
if(( n % a3 )== 0){
c = c * b3 ;
}else{
c = (c + 1) * b3 ;
}
//比较三种情况价格高低,将价格最低的一种赋值给Z
if(a < b && a < c)
z = a ;
if(b < a && b < c)
z = b ;
if(c < a && c < b)
z = c ;
printf("%d\n" , z) ;
return (0) ;
}