题目链接:K小数查询

题意:给你一个长度为$n$序列$A$,有$m$个操作,操作分为两种:

  • 输入$x,y,c$,表示对$i\in[x,y] $,令$A_{i}=min(A_{i},c)$
  • 输入$x,y,k$,表示询问区间$[x,y]$中的第$k$小数

思路:数据范围不是很大,可以分块来做,记录每个块已经更新过的最小值$imin[]$,询问时二分答案,然后求出$[x,y]$区间中小于等于$mid$的数的个数$cnt$,通过判断$cnt$与$k$的大小来改变$l,r$即可

#include <iostream>
#include <algorithm>
#include <cstdio>
#include <vector>
#include <cmath> using namespace std; const int N = ;
const int INF = 0x3f3f3f3f; int block, belong[N], num, l[N], r[N], imin[N];
int n, m, a[N];
vector<int> v[N]; void build()
{
block = sqrt(n);
num = n / block;
if (n % block) num++;
for (int i = ; i <= num; i++)
l[i] = (i - ) * block + , r[i] = i * block;
r[num] = n;
for (int i = ; i <= n; i++)
belong[i] = (i - ) / block + ;
for (int i = ; i <= num; i++) {
imin[i] = INF;
for (int j = l[i]; j <= r[i]; j++)
v[i].push_back(a[j]);
sort(v[i].begin(), v[i].end());
}
} void reset(int x)
{
v[x].clear();
for (int i = l[x]; i <= r[x]; i++) {
a[i] = min(a[i], imin[x]);
v[x].push_back(a[i]);
}
sort(v[x].begin(), v[x].end());
} void update(int x, int y, int c)
{
int bl = belong[x], br = belong[y];
if (bl == br) {
for (int i = x; i <= y; i++)
a[i] = min(a[i], c);
reset(bl);
return;
}
for (int i = x; i <= r[bl]; i++)
a[i] = min(a[i], c);
reset(bl);
for (int i = l[br]; i <= y; i++)
a[i] = min(a[i], c);
reset(br);
for (int i = bl + ; i < br; i++)
imin[i] = min(imin[i], c);
} int query(int x, int y, int c)
{
int bl = belong[x], br = belong[y], cnt = ;
if (bl == br) {
for (int i = x; i <= y; i++)
if (a[i] <= c || imin[bl] <= c) cnt++;
return cnt;
}
for (int i = x; i <= r[bl]; i++)
if (a[i] <= c || imin[bl] <= c) cnt++;
for (int i = l[br]; i <= y; i++)
if (a[i] <= c || imin[br] <= c) cnt++;
for (int i = bl + ; i < br; i++)
if (imin[i] <= c) cnt = cnt + r[i] - l[i] + ;
else cnt = cnt + upper_bound(v[i].begin(), v[i].end(), c) - v[i].begin();
return cnt;
} int ask(int x, int y, int k)
{
int l = -, r = ;
while (l < r) {
int mid = (l + r) / ;
if (query(x, y, mid) >= k) r = mid;
else l = mid + ;
}
return l;
} int main()
{
scanf("%d%d", &n, &m);
for (int i = ; i <= n; i++)
scanf("%d", &a[i]);
build();
for (int i = ; i <= m; i++) {
int kd, x, y, c;
scanf("%d%d%d%d", &kd, &x, &y, &c);
if ( == kd) update(x, y, c);
else printf("%d\n", ask(x, y, c));
}
return ;
}

2020 CCPC Wannafly Winter Camp Day1 - I. K小数查询(分块)的更多相关文章

  1. 2020 CCPC Wannafly Winter Camp Day1 C. 染色图

    2020 CCPC Wannafly Winter Camp Day1 C. 染色图 定义一张无向图 G=⟨V,E⟩ 是 k 可染色的当且仅当存在函数 f:V↦{1,2,⋯,k} 满足对于 G 中的任 ...

  2. 2020 CCPC Wannafly Winter Camp Day1 Div.1&amp F

    #include<bits/stdc++.h> #define forn(i, n) for (int i = 0; i < int(n); i++) #define fore(i, ...

  3. 2020 CCPC Wannafly Winter Camp Day1-F-乘法

    题目传送门 sol:二分答案$K$,算大于$K$的乘积有多少个.关键在于怎么算这个个数,官方题解上给出的复杂度是$O(nlogn)$,那么计算个数的复杂度是$O(n)$的.感觉写着有点困难,自己写了一 ...

  4. 2020 CCPC Wannafly Winter Camp Day2-K-破忒头的匿名信

    题目传送门 sol:先通过AC自动机构建字典,用$dp[i]$表示长串前$i$位的最小代价,若有一个单词$s$是长串的前$i$项的后缀,那么可以用$dp[i - len(s)] + val(s)$转移 ...

  5. Wannafly Camp 2020 Day 1I K小数查询 - 分块

    给你一个长度为\(n\)序列\(A\),有\(m\)个操作,操作分为两种: 输入\(x,y,c\),表示对\(i\in[x,y]\),令\(A_{i}=min(A_{i},c)\) 输入\(x,y,k ...

  6. CCPC Wannafly Winter Camp Div2 部分题解

    Day 1, Div 2, Prob. B - 吃豆豆 题目大意 wls有一个\(n\)行\(m\)列的棋盘,对于第\(i\)行第\(j\)列的格子,每过\(T[i][j]\)秒会在上面出现一个糖果, ...

  7. 2019 wannafly winter camp

    2019 wannafly winter camp Name Rank Solved A B C D E F G H I J K day1 9 5/11 O O O O O day2 5 3/11 O ...

  8. 2019 wannafly winter camp day 3

    2019 wannafly winter camp day 3 J 操作S等价于将S串取反,然后依次遍历取反后的串,每次加入新字符a,当前的串是T,那么这次操作之后的串就是TaT.这是第一次转化. 涉 ...

  9. Wannafly Winter Camp 2020 Day 6J K重排列 - dp

    求 \(K\) 是多少个 \(n\) 元置换的周期.\(T\leq 100, n\leq 50, K \leq 10^{18}\) Solution 置换可以被试做若干个环组成的有向图,于是考虑 dp ...

随机推荐

  1. 数据库 oracle 函数

    static OracleConnection mQracleConnecting = null; public static OracleConnection QracleConnecting { ...

  2. java基础之 数据类型

    数据类型表示要存储在变量中的不同类型的值. 一.Java语言提供了八种基本数据类型.六种数字类型(四个整数型,两个浮点型),一种字符类型,还有一种布尔型. 1. byte byte 数据类型是8位.有 ...

  3. CentOS7下使用C/C++连接MariaDB/MySQL

    前言 连接数据库通常在Java中使用比较多,但是C/C++在Linux下操作数据库也是比较重要的,很多时候都能用得到,在网上查了很多教程,大多写的有些问题,通过自己摸索,终于成功的连接了MariaDB ...

  4. Web API入参,响应规范

    入参绑定 入参应该定义成实体,而不是多个参数,方便扩展.[FromBody]和[FromUrl]特性也最好加上. public ActionResult<Pet> Create([From ...

  5. 1060 Are They Equal (25分)

    1060 Are They Equal (25分) 题目 思路 定义结构体 struct fraction{ string f; int index; } 把输入的两个数先都转换为科学计数法,统一标准 ...

  6. vue中style下scope的使用和坑

    在vue组件中,为了使样式私有化(模块化),不对全局造成污染,可以在style标签上添加scoped属性以表示它的只属于当下的模块,这是一个非常好的举措,但是为什么要慎用呢?因为在我们需要修改公共组件 ...

  7. Light Up Your Business Promotions With LED Keychain

    Imagine you want to insert the car key into the keyhole in the dark. What would you do? You will def ...

  8. 解决:配置虚拟主机,重启apache,[warn] _default_ VirtualHost overlap on port 80, the first has precedence

    http://blog.csdn.net/kaizhu_qin/article/details/17506293 很多第一次配置apache的虚拟主机的时候,以为配置第一个虚拟主机完成以后,以后就不会 ...

  9. linux下grep分析apache日志的命令集合

    https://my.oschina.net/hmc0316/blog/112004 实例:月份英文简写英文全称一月Jan.January二月Feb.February三月Mar.March四月Apr. ...

  10. HTML学习(5)标题、水平线、注释

    HTML 标题 标题(Heading)是通过 <h1> - <h6> 标签进行定义的. <h1> 定义最大的标题. <h6> 定义最小的标题. 注: 浏 ...