【问题描述】
小明决定从下周一开始努力刷题准备蓝桥杯竞赛。他计划周一至周五每天 做 a 道题目,周六和周日每天做 b 道题目。请你帮小明计算,按照计划他将在 第几天实现做题数大于等于 n 题?
【输入格式】
输入一行包含三个整数 a, b 和 n.
【输出格式】
输出一个整数代表天数。
【样例输入】
10 20 99
【样例输出】
8
【评测用例规模与约定】
对于 50% 的评测用例,1 ≤ a, b, n ≤ 106 .
对于 100% 的评测用例,1 ≤ a, b, n ≤ 1018
参考代码:
a,b,n=map(int,input().split())
week=5*a+2*b#一周做的题数
d1=(n//week)*7#看这些题能做够几周 *7算天数
lea=n%week#看不满足一周的还剩下多少题
if lea<=5*a:#能在周一到周五做完
if(lea%a==0):#刚好某一天做完
s=lea//a
elif(lea%a>0):#剩下的不足一天的量按一天算
s=(lea//a)+1
if lea>5*a:#在周六日做完
t=lea-(5*a)#把前五天的减去
if(t%b==0):#如果刚好某天做完
s=5+(t//b)#记得加上前五天的
elif(t%b>0):
s=5+(t//b)+1
print(d1+s)#最后把够一周的,不够一周的都加上
知识补充:
三目运算符:
上面两个大的判断也可以用三目运算符算:
if lea<=5*a:
s=lea//a+(1 if lea%a else 0)#跟上面一样,当lea%a为真(不为0)时返回1,
#否则返回0
if lea>5*a:
s=5+(lea-(5*a))//b+(1 if (lea-(5*a))%b else 0)