UOJ#52. UR #4元旦激光炮(交互)

Posted zwfymqz

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了UOJ#52. UR #4元旦激光炮(交互)相关的知识,希望对你有一定的参考价值。

题意

给出三个已经排好序的数组$a, b, c$

在$100$次询问内找出第$k$小的元素

Sol

一种很显然的$log^2n$的做法:首先在$a$中二分,然后再$b,c$中二分。这样可以得到$60$分的好成绩。

然而这算法就没什么优化的空间了。。。

考虑另一种做法。

我们每次对三个数组询问第$frac{3}{k}$个数。

然后我们可以直接把最小对应的那一段抛弃。正确性显然吧。或者你可以考虑一下最坏情况

那么$k$就缩小了$frac{1}{3}$

算一下,查询次数不会超过$99$。

具体可以这么算

技术分享图片

边界好难调啊,还是Orz std吧

#include "kth.h"
#include <stdio.h>
#include <assert.h>
#include<algorithm>
using namespace std;
int query_kth(int n_a, int n_b, int n_c, int k) {
    int nowa = 0, nowb = 0, nowc = 0, mi;
    while(k) {
        int cur = (k - 2) / 3;
        int vala = get_a(nowa + cur),
            valb = get_b(nowb + cur), 
            valc = get_c(nowc + cur);
        mi = min(vala, min(valb, valc));
        cur++;
        if(mi == vala) nowa += cur;
        else if(mi == valb) nowb += cur;
        else nowc += cur;
        k -= cur;
    }
    return mi;
}

 

以上是关于UOJ#52. UR #4元旦激光炮(交互)的主要内容,如果未能解决你的问题,请参考以下文章

UR #4元旦激光炮

uoj#51[UR #4]元旦三侠的游戏 博弈论+dp

uoj167 元旦老人与汉诺塔(记忆化搜索)

UOJ#53. UR #4追击圣诞老人 树链剖分 k短路

UOJ#21UR#1缩进优化

UOJ83UR #7水题出题人(提交答案题)