星际穿越, 网易笔试题
Posted lixyuan
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了星际穿越, 网易笔试题相关的知识,希望对你有一定的参考价值。
二分查找
(x+x^2=x(x+1)=h) 二分查找求解。
x下界为0, 上界不好找(如果设为h, java中long类型溢出)。我们转化问题为查找x+1,下界为1, 上界为 (lceil sqrt{h}
ceil) 。
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
long h = sc.nextLong();
long l = 1L, r = (long)Math.sqrt(h) + 1L;
while(l < r) {
long mid = (l+r+1) / 2;
if(mid*(mid-1) <= h)
l = mid;
else
r = mid-1;
}
System.out.println(l-1);
}
}
以上是关于星际穿越, 网易笔试题的主要内容,如果未能解决你的问题,请参考以下文章