1/7的小数点后2020位的数字是_九八K

1/7的小数点后2020位的数字是_九八K给定长度为 N 的整数序列 A,下标为 1∼N。现在要执行 M 次操作,其中第 i 次操作为给出三个整数 li,ri,ki,求 A[li],A[li+1],…,A[ri] (即 A 的下标区间 [li,ri])中第 ki 小的数是多少。输入格式第一行包含两个整数 N 和 M。第二行包含 N 个整数,表示整数序列 A。接下来 M 行,每行包含三个整数 li,ri,ki,用以描述第 i 次操作。输出格式对于每次操作输出一个结果,表示在该次操作中,第 k 小的数的数值。每个结果占一行。数据范围

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

给定长度为 N 的整数序列 A,下标为 1∼N。

现在要执行 M 次操作,其中第 i 次操作为给出三个整数 li,ri,ki,求 A[li],A[li+1],…,A[ri] (即 A 的下标区间 [li,ri])中第 ki 小的数是多少。

输入格式
第一行包含两个整数 N 和 M。

第二行包含 N 个整数,表示整数序列 A。

接下来 M 行,每行包含三个整数 li,ri,ki,用以描述第 i 次操作。

输出格式
对于每次操作输出一个结果,表示在该次操作中,第 k 小的数的数值。

每个结果占一行。

数据范围
N≤105,M≤104,|A[i]|≤109

输入样例:
7 3
1 5 2 6 3 7 4
2 5 3
4 4 1
1 7 3
输出样例:
5
6
3
#include <iostream>
#include <cstring>
#include <algorithm>
#include <vector>
using namespace std;
const int N = 1e5+10, M = 1e4+10;
int w[N], root[N], idx;
vector<int> pos;
int n, m;
struct Node
{ 
   
    int l, r, cnt;
}t[N * 4 + 17 * N];
void build(int &u, int L, int R)
{ 
   
    u = ++ idx;
    if(L == R) return;
    int mid = L + R >> 1;
    build(t[u].l, L, mid); build(t[u].r, mid + 1, R);
}
int getp(int x)
{ 
   
    return lower_bound(pos.begin(), pos.end(), x) - pos.begin();
}
void insert(int p, int &q, int L, int R, int k)
{ 
   
    q = ++ idx; t[q] = t[p]; t[q].cnt ++;
    if(L == R) return;
    int mid = L + R >>1;
    if(k <= mid) insert(t[p].l, t[q].l, L, mid, k);
    if(k > mid) insert(t[p].r, t[q].r, mid + 1, R, k);
}
int query(int p, int q, int k, int L, int R)
{ 
   
    if(L == R) return L;
    int mid = L + R >> 1;
    int cnt = t[t[q].l].cnt - t[t[p].l].cnt;
    if(cnt >= k) return query(t[p].l, t[q].l, k, L, mid);
    if(cnt < k) return query(t[p].r, t[q].r, k - cnt, mid + 1, R);
    
}
int main()
{ 
   
    scanf("%d%d", &n, &m);
    for(int i = 1; i <= n; ++ i)
    { 
   
        scanf("%d", &w[i]);
        pos.push_back(w[i]);
    }
    sort(pos.begin(), pos.end());
    pos.erase(unique(pos.begin(), pos.end()), pos.end());
    build(root[0], 0, pos.size() - 1);
    for(int i = 1; i <= n; ++ i) insert(root[i - 1], root[i], 0, pos.size() - 1, getp(w[i]));
    while(m -- )
    { 
   
        int l, r, k; scanf("%d%d%d", &l, &r, &k);
        printf("%d\n", pos[query(root[l - 1], root[r], k, 0, pos.size() - 1)]);
    }
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168596.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月9日 下午2:00
下一篇 2022年8月9日 下午2:00


相关推荐

  • 移远 EC20 模组(4G通信模组)AT指令测试 TCP 通信过程

    移远 EC20 模组(4G通信模组)AT指令测试 TCP 通信过程1 环境准备 1 1 硬件准备 EC20 通信模组 USB 转串口 一条 USB 线 1 2 软件准备 QCOM 串口助手 EC20 通信模组测试 AT 命令脚本 EC20 ini WindowsUSB 驱动使用 AT 指令测试移远 EC20 模组有两种方法 第一种是使用 USB 转串口连接模组 另一种是直接使用 USB 线连接到模组 使用虚拟 AT 串口测试 本文使用第二种方法 将模组直接通过 USB 线连接到

    2026年3月19日
    2
  • 【Linux教程】Ubuntu Linux 更换源教程

    【Linux教程】Ubuntu Linux 更换源教程UbuntuLinux 更换源教程因为 Ubuntu 自带的源已经老旧 下载速度慢 而且不稳定本教程告诉大家如何更换 Ubuntu 源到国内几个比较好的源更换源步骤如下 备份源列表 sudocp etc apt sources list etc apt sources list bak 命令行打开 sources list 文件 sudogedit etc apt sourc

    2026年3月18日
    2
  • implementation和api的区别

    implementation和api的区别关于 implementati 和 api 的区别 一共分为两个方面 一 编译范围关于这一部分 参考官网 说的很清楚 implementati Gradle 会将依赖项添加到编译类路径 并将依赖项打包到构建输出 不过 当您的模块配置 implementati 依赖项时 会让 Gradle 了解您不希望该模块在编译时将该依赖项泄露给其他模块 也就是说 其他模块只有在运行时才能

    2026年3月17日
    2
  • 使用DatabaseMetaData获取mysql表的注释

    使用DatabaseMetaData获取mysql表的注释privateList<String>getTableNames(DatabaseMetaDatamd)throwsSQLException{ArrayList<String>tables=newArrayList<String>();ResultSetrs=md.getTables(null,null,””,null);while(rs.next()){.

    2022年6月19日
    25
  • rk3399调试ov2659(camera模块@dvp接口)–源码分析

    rk3399调试ov2659(camera模块@dvp接口)–源码分析  之前整理的“rockchipsensorcore框架”和rkisp下的v4l2框架有点像,只不过v4l2框架有点大(而且不支持摄像头热插拔)。其实接触越多Linux子系统越发觉得这些子系统处理思想大同小异。   这种"核…

    2022年6月8日
    115
  • CubieBoard 简单入门

    CubieBoard 简单入门大约一个月之前折腾的部分记录,当时没有完全完成,就着手其他事情了,这是存在LiveWriter中的草稿,先发出来吧,后来花了一段时间移植Qt,一直遇到了点问题,并没有完全跑通,后续估计也没有时间再继

    2022年7月4日
    24

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号