包含一些ai和bi的集用S来表示,x = max(sigma(ai)/sigma(bi),i 属于S) ,k 表示S的大小,k= |S|。
x和k之间具有单调性。k0 < k1 → x0 ≥ x1。单调性对x(k)的反函数k(x)也成立。现在的问题是k已经给出,
那么猜测一个x,通过和sigma(ai)/sigma(bi) 作差得到大小关系以便收敛区间。
要求x可以做一点变形sigma(ai)/sigma(bi) - k*x → sigma(ai - x*b),x是max值,和一个常数作差以后也是最大的,
因此选取前k大元素ai - x*b求和就可以得到差值。
(还有一种很迷的迭代法也可以收敛
/********************************************************** ------------------ ** author AbyssalFish ***********************************************************/#include #include #include #include #include #include #include #include #include