期末来临,班长决定将剩余的班费x元钱用于购买若干支笔奖励给一些学习好的同学。
已知商店里有三种钢笔,单价分别为6元、5元和4元。班长想买尽量多的钢笔,同时他又不想剩余钱。
请你帮助班长制定一种买笔的方案。
分析:想买尽量多的笔,如果都买4元的笔肯定可以买最多支笔。因此,最多买笔为x/4支。
但是班长想把钱都用完,所以可以按下面的方法把钱用完:
若买完x/4支4元钱的笔还剩1元,则4元钱的笔少买1支,换成一支5元笔即可;
若买完x/4支4元钱的笔还剩2元,则4元钱的笔少买1支,换成一支6元笔即可;
若买完x/4支4元钱的笔还剩3元,则4元钱的笔少买2支,换成一支5元笔和一支6元笔即可。
#include<stdio.h>
int main()
{
int a,b,c,x,y;
scanf("%d",&x);
c=x/4;//4元买的最多数目
y=x%4;//买完c支4元笔剩余的钱y
switch(y)
{
case 0:a=0;b=0;break;
case 1:a=0;b=1;c--;break;
case 2:a=1;b=0;c--;break;
case 3:a=1;b=1;c-=2;break;
}
printf("买%d支6元的笔,买%d支5元的笔,买%d支4元的笔\n",a,b,c);
return 0;
}