1、题目大意:就是给你三个数组啦,然后让你找到其中的第K大,但是,不可以直接访问数组,必须通过一种函数,最后的分数

是看调用几次这个函数,100次以内10分,2000以内6分。。。。

2、分析:最开始,并不会100分啦,所以就敲了一个六十分的代码,

就是二分一个值,然后再套一个二分验证一下,这样就过了60分(可还是憋了one hour)

#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <ctime>
#include <kth.h>
using namespace std;
int get_a_min(int na, int value){
    if(na == 0) return 0;
    int l = 0, r = na - 1;
    int odl = 0, odr = 0;
    while(l < r){
        int mid = (l + r) / 2;
        if(get_a(mid) > value) r = mid - 1;
        else l = mid;
        if(odl == l && odr == r) break;
        odl = l; odr = r;
    }
    if(get_a(r) <= value) return r + 1;
    else return l + 1;
}
int get_b_min(int nb, int value){
    if(nb == 0) return 0;
    int l = 0, r = nb - 1;
    int odl = 0, odr = 0;
    while(l < r){
        int mid = (l + r) / 2;
        if(get_b(mid) > value) r = mid - 1;
        else l = mid;
        if(odl == l && odr == r) break;
        odl = l; odr = r;
    }
    if(get_b(r) <= value) return r + 1;
    else return l + 1;
}
int get_c_min(int nc, int value){
    if(nc == 0) return 0;
    int l = 0, r = nc - 1;
    int odl = 0, odr = 0;
    while(l < r){
        int mid = (l + r) / 2;
        if(get_c(mid) > value) r = mid - 1;
        else l = mid;
        if(odl == l && odr == r) break;
        odl = l; odr = r;
    }
    if(get_c(r) <= value) return r + 1;
    else return l + 1;
}
int query_kth(int n_a, int n_b, int n_c, int k){
    int l = 0, r = max(max(get_a(n_a - 1), get_b(n_b - 1)), get_c(n_c - 1));
    int odl = 0, odr = 0;
    while(l < r){
        int mid = (l + r) / 2;
        int wt = get_a_min(n_a, mid) + get_b_min(n_b, mid) + get_c_min(n_c, mid);
        if(wt < k) l = mid;
        else r = mid;
        if(odl == l && odr == r) break;
        odl = l; odr = r;
    }
    int o1 = get_a_min(n_a, l) + get_b_min(n_b, l) + get_c_min(n_b, l);
    int o2 = get_a_min(n_a, r) + get_b_min(n_b, r) + get_c_min(n_b, r);
    if(o1 >= k) return l + 1;
    else return r;
}

第k/3个数求出来,然后就是选最小的那个数组,
这个数组的前k/3个数都没有用了,我们就可以删掉,然后每次删删删,于是递归若干次,就可以100分了
#include"kth.h"
#include<iostream>
using namespace std;
int query_kth(int n_a,int n_b,int n_c,int k){
    int ca=0,cb=0,cc=0;
    int t_min;
    while(k){
        int t=max(0,k/3-1); int ta=get_a(ca+t),tb=get_b(cb+t),tc=get_c(cc+t);
        t_min=min(ta,min(tb,tc));t++;
        if(t_min==ta)ca+=t; else if(t_min==tb)cb+=t; else cc+=t; k-=t;
    }
    return t_min;
}

UOJ52——【UR #4】元旦激光炮的更多相关文章

  1. UOJ.52.[UR #4]元旦激光炮(交互 思路)

    题目链接 \(Description\) 交互库中有三个排好序的,长度分别为\(n_a,n_b,n_c\)的数组\(a,b,c\).你需要求出所有元素中第\(k\)小的数.你可以调用至多\(100\) ...

  2. #52. 【UR #4】元旦激光炮 (交互式题)

    链接:http://uoj.ac/problem/52 刚刚越过绝境长城,只见天空中出现了炫目的光芒 —— 圣诞老人出现了. 元旦三侠立刻进入战斗.生蛋侠.圆蛋侠和零蛋侠分别有 na,nb,ncna, ...

  3. [UOJ #52]【UR #4】元旦激光炮

    题目大意:交互题,给你三个有序数组,长度分别为$n\_a,n\_b,n\_c$,都不超过$10^5$.三个函数$get\_a(i),get\_b(i),get\_c(i)$,分别返回$a_i,b_i, ...

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

    题意 给出三个已经排好序的数组$a, b, c$ 在$100$次询问内找出第$k$小的元素 Sol 一种很显然的$log^2n$的做法:首先在$a$中二分,然后再$b,c$中二分.这样可以得到$60$ ...

  5. Uoj 52. 【UR #4】元旦激光炮 神题+交互题

    Code: #include "kth.h" #include<iostream> int minn(int x,int y){return x<y?x:y;}; ...

  6. UOJ 52 元旦激光炮

    http://uoj.ac/problem/52 题意:每次可以得到3个序列中 思路:每次分别取出三个序列的K/3长度的位置,取最小的那个,然后每次减掉它,总复杂度是Nlog3N #include & ...

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

    题目描述 给出 $n$ 和 $m$ ,$m$ 次询问.每次询问给出 $a$ 和 $b$ ,两人轮流选择:将 $a$ 加一或者将 $b$ 加一,但必须保证 $a^b\le n$ ,无法操作者输,问先手是 ...

  8. ZJOI2019一轮停课刷题记录

    Preface 菜鸡HL终于狗来了他的省选停课,这次的时间很长,暂定停到一试结束,不过有机会二试的话还是可以搞到4月了 这段时间的学习就变得量大而且杂了,一般以刷薄弱的知识点和补一些新的奇怪技巧为主. ...

  9. 【UOJ#51】【UR #4】元旦三侠的游戏(博弈论)

    [UOJ#51][UR #4]元旦三侠的游戏(博弈论) 题面 UOJ 题解 考虑暴力,\(sg[a][b]\)记录\(sg\)函数值,显然可以从\(sg[a+1][b]\)和\(sg[a][b+1]\ ...

随机推荐

  1. JavaScript之继承(原型链)

    JavaScript之继承(原型链) 我们知道继承是oo语言中不可缺少的一部分,对于JavaScript也是如此.一般的继承有两种方式:其一,接口继承,只继承方法的签名:其二,实现继承,继承实际的方法 ...

  2. ios动态添加属性的几种方法

    http://blog.csdn.net/shengyumojian/article/details/44919695 在ios运行过程中,有几种方式能够动态的添加属性. 1-通过runtime动态关 ...

  3. Win7系统开放C盘下文件夹Everyone权限

    安装软件时遇到这样的情况:我就是管理员权限啊,怎么会安装有问题呢? 后来知道,用户名即使分配了你是管理员权限,有些文件还是有限制的(特别是C盘) 昨天遇到一个问题,有个文件夹里的隐藏文件就是无法显示, ...

  4. C++中int,float,string,char*的转换(待续)

    //float转string char a[100]; float b = 1.234; sprintf(a, "%f", b); string result(a); //int转 ...

  5. iOS / Android 移动设备中的 Touch Icons

    上次转载了一篇<将你的网站打造成一个iOS Web App>,但偶然发现这篇文章的内容有些是错误的——准确来说也不是错误,只是不适合自半年前来的情况了(也可以说是iOS7 之后的时间)—— ...

  6. Java Web学习笔记-Servle生命周期

    Servlet会在服务器启动或第一次请求该Servlet的时候开始生命周期,在服务器停止的时候结束生命周期. 无论请求多少次Servlet,最多只有一个Servlet实例.多个客户端并发请求Servl ...

  7. JavaBean简单示例

    本示例说明: 从Login.jsp中输入用户名和密码,提交,在NewFile.jsp中显示信息. ----- 类要放在一个包中!!! UserB 类文件 package model; public c ...

  8. 通过XHR  API来下载和上传图片

    1.不用HTML中的img标签来下载图片,通过XHR  api来下载图片: var xhr = new XMLHttpRequest(); xhr.open('GET','/img/tooth-int ...

  9. 给IOS系统的微信页面赋Title

    给页面赋一个title是最平常不过的事情了,不过在IOS下动态给页面赋title可不是平常的事情. 看代码: function setIOStitle(title) { $body = $('body ...

  10. ecshop Admin后台商品列表处(上架、下架、精品...取消精品)增加操作

    相关文件:goods.php,goods_list.htm 思路: a.增添连接“转移仓库” b.在goods.php,读取仓库列表数据,并且实例化 c. 在goods_list.htm循环数据.点击 ...