UVALive 7500 Boxes and Balls (二分)

题目链接

题意:一开始有一个盒子,盒子里有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);
	}
}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值