Skip to main content

二分

参考资料

二分

check 函数的返回值应为 {0,0,,0,0,1,1,,1,1}\set{0,0,\dots,0,0,1,1,\dots,1,1}

二分结束后,ll 为第一个 11 的位置,l1l-1 为最后一个 00 的位置。

83 Bcpp
int l=x,r=y+1;
while(l<r)
{
int mid=l+r>>1;
if(check(mid))r=mid;
else l=mid+1;
}

三分

单峰函数如果找最大值 f(m1)>f(m2),找最小值 f(m1)<f(m2)

103 Bcpp
double l=x,r=y;
while(r-l>eps)
{
double m1=(l*2+r)/3,m2=(l+r*2)/3;
if(f(m1)>f(m2))r=m2;
else l=m1;
}

例题

输入 nn 个不超过 10910^9 的单调不减的(就是后面的数字不小于前面的数字)非负整数 a1,a2,,ana_1,a_2,\dots,a_{n},然后进行 mm 次询问。对于每次询问,给出一个整数 qq,要求输出这个数字在序列中第一次出现的编号,如果没有找到的话输出 1-1

给定 nn 个形如 ax2+bx+cax^2+bx+c 的二次函数 f1(x),f2(x),,fn(x)f_1(x),f_2(x),\dots,f_n(x),设 F(x)=maxfi(x)F(x)=\max f_i(x),求 F(x)F(x) 在区间 [0,1000][0,1000] 上的最小值。

给出一个 NN 次函数,保证在范围 [l,r][l, r] 内存在一点 xx,使得 [l,x][l, x] 上单调增,[x,r][x, r] 上单调减。试求出 xx 的值。

有两个城市,中间相隔着一条笔直的河,现在要修路修桥将这两个城市联通,请找出一种方案使总的花费最小。