有个建筑工地还有工程要做。我们需要一定数量的工人来完成这些任务。每个工人都有相同的工作能力,他们不能处理超过这个限制。因此,就某项工程而言,所需的工人数目如下:
works是workerCapacity的整数倍数,那么workers将是works / workerCapacity的简单除法。works不是workerCapacity的整数倍数,那么在除法之后,我们需要增加1。如果容量= 10,100项工作需要10名工人,而101项工作需要11名工人。以下是我的实现:
public int getNumWorkers(int works) {
int workers = works / workerCapacity;
if (works % workerCapacity != 0) {
workers++;
}
return workers;
}我的问题是:我们能否将第2-5行简化为一行?
发布于 2016-06-24 21:56:40
可以,停那儿吧。在分割之前添加workerCapacity-1,如下所示:
return (works+workerCapacity-1) / workerCapacity;如果workerCapacity平均地除以works (即works % workerCapacity == 0),那么添加workerCapacity-1就太少,无法改变答案。如果余数大于零,添加workerCapacity-1将使除法结果增加1。
发布于 2016-06-24 22:15:22
只管用
return (int) Math.ceil((double) works / workerCapacity);Math.ceil将其舍入任何分数到下一个整数,这比将workerCapacity - 1添加到workers明显。
发布于 2016-06-24 22:02:24
就用这个
返回(int)(Math.ceil(works / workCapacity));
如果浮点数不是整数,则Math.ceil方法返回下一个整数
https://stackoverflow.com/questions/38022634
复制相似问题