P5709 【深基2.习6】Apples Prologue / 苹果和虫子

题目描述

小 B 喜欢吃苹果。她现在有 𝑚m(1≤𝑚≤100)个苹果,吃完一个苹果需要花费 𝑡(0≤𝑡≤100)分钟,吃完一个后立刻开始吃下一个。现在时间过去了 𝑠(1≤𝑠≤10000)分钟,请问她还有几个完整的苹果?

输入格式

输入三个非负整数表示 𝑚,𝑡,𝑠。

输出格式

输出一个整数表示答案。

输入输出样例

输入 #1

50 10 200

输出 #1

30

说明/提示

如果你出现了 RE,不如检查一下被零除?

首先,八尾勇吃了𝑠/𝑡个苹果,那么问题就来了:如果𝑡是0,那么八尾勇肯定能吃完所有的苹果,输出0,但是0又不能做除数,这种情况要特判。

接着往下想,如果𝑠是𝑡的整数倍,那么八尾勇就吃了𝑠/𝑡个完整的苹果,剩下𝑚−𝑠/𝑡个完整的苹果;如果𝑠s并不是是𝑡t的整数倍,八尾勇就吃了𝑠/𝑡个完整的苹果和一个残缺的苹果,那么就有𝑠/𝑡+1个苹果不完整了,剩下𝑚−𝑠/𝑡−1个苹果。可是:说不定他在𝑠秒内就吃完了这堆苹果了呢,那么就没有剩下的苹果,输出0。

上代码:

#include<bits/stdc++.h>//万能头文件
using namespace std;
int m,t,s;
int main()
{
	cin>>m>>t>>s;
	if(t==0)//特判t=0的情况
	{
		cout<<0<<endl;
		return 0;
	}
	if(s%t==0)//如果s是t的整数倍
		cout<<max(m-s/t,0)<<endl;
	else//如果不是
		cout<<max(m-s/t-1,0)<<endl;
	return 0;//程序结束
}

程序中max(a,b)就是a,b中的最大值,如果𝑚−𝑠/𝑡比0小,大的就是0了,输出的就是0。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值