题目链接: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. pytest学习5-mark用例分类

    使用Mark标记测试用例 通过使用pytest.mark你可以轻松地在测试用例上设置元数据.例如, 一些常用的内置标记: skip - 始终跳过该测试用例 skipif - 遇到特定情况跳过该测试用例 ...

  2. js基础之--变量 作用域和内存问题

    基本类型:Undefind Null Boolean Number String 引用类型: 对象 在操作对象时,实际上实在操作对象的引用而不是实际的对象.为此,引用类型的值是按引用访问的. 从一个变 ...

  3. 松软科技Web课堂:AJAX 简介

    AJAX AJAX 并不是编程语言. AJAX 是一种从网页访问 Web 服务器的技术. AJAX 代表异步 JavaScript 和 XML. AJAX 实例解释 HTML 页面 <!DOCT ...

  4. Ubuntu16.04配置

    一.将源更换为国内的源,这样下载和更新软件的速度会快很多.将/etc/apt/sources.list文件的内容更换为如下: #默认注释了源码镜像以提高 apt update 速度,如有需要可自行取消 ...

  5. 【StarUML】 活动图

    StarUML中的活动图本质上是流程图,活动图相对来说,更加专业,它有对信号的处理,对状态动作.数据区别表示,使得更清晰地了解控制流的走向. 1.基本元素 a.活动状态图(Activity).动作状态 ...

  6. 1 学习wcf 编写简单的WCF服务流程 并发布在IIS上

    学习笔记 学习大佬的博客 https://www.cnblogs.com/iamlilinfeng/archive/2012/09/25/2700049.html  写一遍加深印象 图片看不清楚的 可 ...

  7. angular项目实现mqtt的订阅与发布 ngx-mqtt

    angular项目实现mqtt的订阅与发布 如果要写一个exe可执行文件,可以使用angular编写,然后使用electron打包成一个exe文件. https://github.com/maxime ...

  8. AJAX--XMLHttpRequest对象

    创建XMLHttpRequest对象 XMLHttpRequest是AJAX的基础. 所有现代浏览器(IE7+.Firefox.Chrome.Safari以及Opera)均内建XMLHttpReque ...

  9. HTML学习(15)框架

    通过使用框架,你可以在同一个浏览器窗口中显示不止一个页面. <iframe src="//www.taobao.com" name="iframe_a" ...

  10. sqlserver 优化语句小助手

    我们在开发的过程中,经常会遇到一些性能差的问题,此刻我的解决思路一般是,首先在浏览器端监控查看是哪一个调用的方法占用的时间比较长如下图,然后会根据方法定位到具体的方法,然后可能是自己写的遗传sql语句 ...