问题
代码注释
1214: 盐水的故事
时间限制: 1 Sec 内存限制: 128 MB
提交: 1181 解决: 476
题目描述
挂盐水的时候,如果滴起来有规律,先是滴一滴,停一下;然后滴二滴,停一 下;再滴三滴,停一下…,现在有一个问题:这瓶盐水一共有VUL毫升,每一滴是D毫升,每一滴的速度是一秒(假设最后一滴不到D毫升,则花费的时间也 算一秒),停一下的时间也是一秒这瓶水什么时候能挂完呢?
输入
输入数据占一行,由VUL和D组成,其中0< D< VUL< 5000。
输出
请输出挂完盐水需要的时间。
样例输入 Copy
10 1
样例输出 Copy
13
代码
#include <iostream>
using namespace std;
int main() {
int VUL, D;
cin >> VUL >> D;
int totTime = 0;
int drops = 1;
while (VUL) {
VUL -= D * drops;
if (VUL > 0) {
totTime += drops + 1;
drops++;
}
else if (VUL == 0) {
totTime += drops;
break;
}
else {
VUL += D * drops;
totTime += (VUL % D) == 0 ? VUL / D : VUL / D + 1;
break;
}
}
cout << totTime << endl;
return 0;
}
注释
VUL += D * drops; // 返回上一次滴完后的值,重新计算本次滴水的时间
totTime += (VUL % D) == 0 ? VUL / D : VUL / D + 1;
// (VUL % D) == 0 ? VUL / D : VUL / D + 1
// 上面是三木运算符,处理整除的特殊情况(不能整除的,则是结果再加 1)
小结
自己动手实践最关键
眼高手低是不行的
不懂的地方,多思考,多参考,要把握好度,提升自己的效率
题意要理解清楚,多刷题吧!多看算法视频吧!