2020 CCPC Wannafly Winter Camp Day1 - I. K小数查询(分块)
题目链接: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小数查询(分块)的更多相关文章
- 2020 CCPC Wannafly Winter Camp Day1 C. 染色图
2020 CCPC Wannafly Winter Camp Day1 C. 染色图 定义一张无向图 G=⟨V,E⟩ 是 k 可染色的当且仅当存在函数 f:V↦{1,2,⋯,k} 满足对于 G 中的任 ...
- 2020 CCPC Wannafly Winter Camp Day1 Div.1& F
#include<bits/stdc++.h> #define forn(i, n) for (int i = 0; i < int(n); i++) #define fore(i, ...
- 2020 CCPC Wannafly Winter Camp Day1-F-乘法
题目传送门 sol:二分答案$K$,算大于$K$的乘积有多少个.关键在于怎么算这个个数,官方题解上给出的复杂度是$O(nlogn)$,那么计算个数的复杂度是$O(n)$的.感觉写着有点困难,自己写了一 ...
- 2020 CCPC Wannafly Winter Camp Day2-K-破忒头的匿名信
题目传送门 sol:先通过AC自动机构建字典,用$dp[i]$表示长串前$i$位的最小代价,若有一个单词$s$是长串的前$i$项的后缀,那么可以用$dp[i - len(s)] + val(s)$转移 ...
- 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 ...
- CCPC Wannafly Winter Camp Div2 部分题解
Day 1, Div 2, Prob. B - 吃豆豆 题目大意 wls有一个\(n\)行\(m\)列的棋盘,对于第\(i\)行第\(j\)列的格子,每过\(T[i][j]\)秒会在上面出现一个糖果, ...
- 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 ...
- 2019 wannafly winter camp day 3
2019 wannafly winter camp day 3 J 操作S等价于将S串取反,然后依次遍历取反后的串,每次加入新字符a,当前的串是T,那么这次操作之后的串就是TaT.这是第一次转化. 涉 ...
- Wannafly Winter Camp 2020 Day 6J K重排列 - dp
求 \(K\) 是多少个 \(n\) 元置换的周期.\(T\leq 100, n\leq 50, K \leq 10^{18}\) Solution 置换可以被试做若干个环组成的有向图,于是考虑 dp ...
随机推荐
- 转载:TDM协议
转自http://www.wangdali.net/i2s/ 1. PCM简介 PCM (Pulse Code Modulation) 是通过等时间隔(即采样率时钟周期)采样将模拟信号数字化的方法.图 ...
- 将图片中的一部分图片用ps进行旋转
先用选择工具选择你要进行变动的那部分图像,至于选择的方法有多种而且得看你的图片来决定采取何种选择方法.然后在英文输入状态下按下“CTRL+T”出现变换框,你将鼠标移动对角点上,当鼠标变为一种旋转的图标 ...
- echarts修改X、 Y坐标轴字体的颜色
1.背景:在项目中常常会用到echarts的实例,根据不同的需求字体颜色需要变化,如图,要切合背景,就需要更改字体颜色 2.解决方案 xAxis : [ { type : 'category', da ...
- SpringBoot整合WEB开发--(三)文件上传
文件上传: Java中文件上传一共涉及到两个组件,CommonsMultipartResolver和StandardServletMultipartResolver,其中CommonsMultipar ...
- 算法竞赛入门经典第二版 回文词P49
#include<bits/stdc++.h> using namespace std; char rev[]="A 3 HIL JM O 2TUVWXY51SE Z 8 &qu ...
- windows7安装 npm和cnpm
1.node.js下载地址: https://nodejs.org/en/download/ 我选择的安装路径是D:\files\nodejs 2.查看安装是否成功 3.创建文件夹 在D:\files ...
- centos useradd 命令详解
useradd 命令 Usage: useradd [options] LOGIN useradd -D useradd -D [options] Options: -b, --base-dir BA ...
- springboot引入Oracle依赖
最近学习spring boot,在网上找一些项目学习,有的项目引入了oracle驱动包,自己搭建一直不成功,百度发现说是权限问题无法下载. 然后参考下面博客终于解决:springboot引入Oracl ...
- Vue - 解决路由过渡动画抖动问题
前言 Vue-Router 作为 Vue 的核心模块,它为我们提供了基于组件的路由配置.路由参数等功能,让单页面应用变得更易于管理.良好的路由管理尤为重要,比如路由拦截.路由懒加载.路由权限等都在开发 ...
- 链剖-进阶ing-填坑-NOIP2013-货车运输
This article is made by Jason-Cow.Welcome to reprint.But please post the writer's address. http://ww ...