题意:一开始有一个盒子,盒子里有n个球,然后进行如题中的操作,最后使得盒子的状态能保持在一个稳定的状态。
思路:稳定的状态下,盒子中球的数量一定是维持1,2,3,4......k-1,k
因此在一开始盒子中球的数量一定要可以是一个从1到k等差序列的和,否则,不能维持稳定。
以此得知我们要做的是,从1到n中找出一个数k,到k为止的等差数列和不超过n且是最大的那个数列和就行,这样就想到用二分
要注意下的是,根据等差数列公式(1+a)*a/2以及n的范围最大是10^18,所以a最大值可以给个估计值2e9
代码:
import java.util.Scanner;
public class Main{
static Scanner sc = new Scanner(System.in);
static int t;
static long n;
public static void main(String[] args) {
t = sc.nextInt();
for(int k = 1; k <= t; k++) {
n = sc.nextLong();
long l = 0, r = (long) 2e9, ans = 1;
while(l <= r) {
long mid = (l + r) / 2;
long sum = (1 + mid) * mid / 2;
if(sum <= n) {
ans = sum;
l = mid + 1;
}
else
r = mid - 1;
}
System.out.println("Case #"+k+": "+ans);
}
System.exit(0);
}
}