NC21125 践踏
题目
题目描述
首先给定一个定值k,支持如下操作(在数轴上)
- 加入一条线段[l,r]
- 删除一条已经存在的线段
- 给定x,问有多少个区间包含x+kt,其中t是一个整数变量,即t ∈ Z
比如说当x=2,k=3的时候,区间[7,10]是应该算入答案的,因为x+2k=8,且7 ≤ 8 ≤ 10
如果n=0,那么你只需要输出一行"fafa"然后结束程序即可(注意不输出双引号)
输入描述
第一行两个整数n,k,分别表示操作次数以及定值k
之后有n行,每行先输入一个整数op,之后分类讨论:
- op=1,此时再输入[l,r],表示加入一个区间[l,r]
- op=2,此时再输入[l,r],表示删除区间[l,r],保证这个区间存在(如果存在多个相同的区间,那么只需要删除其中的任意一个)
- op=3,此时再输入x,之后需要输出答案并换行
输出描述
对于每一个op=3的操作,输出查询结果后换行
示例1
输入
10 7
1 3393 14151
3 13229
1 3427 18356
1 7602 20138
1 8566 28714
1 1076 32552
2 3427 18356
2 8566 28714
3 10962
1 387 7783
输出
1
3
说明
(以下内容与本题无关)
这个样例,无疑是善良的出题人无私的馈赠。
大量精心构造的 n ≤ 100 的测试数据,涵盖了测试点中所有出现性质的组合。
你可以利用这个测试点,对自己的程序进行全面的检查。
足量的数据组数、不大的数据范围和多种多样的数据类型,能让程序中的错误无处遁形。
出题人相信,这个美妙的样例,可以给拼搏于 AC 这道题的逐梦之路上的你,提供一个有力的援助。
示例2
输入
0 0
输出
fafa
备注
一共有20个测试点,每个测试点5分
有4个测试点保证:\(n≤1000\)
有另外5个测试点保证:\(n≤10000\)
对于全部数据,保证:
\(0 ≤ n,k ≤ 10^5\) ,\(0 ≤ l ≤ r ≤ 10^9\) , \(0 ≤ x ≤ 10^9\)
题解
知识点:树状数组,离散化,数论。
\(n = 0\) 时,输出 fafa 。
- \(k = 0\) 时,需要区间修改、单点询问,可以用树状数组维护,需要先离散化区间端点。
- \(k \neq 0\) 时,需要区间修改、固定间隔的多点询问,注意到间隔是固定的,因此区间覆盖可以在模 \(k\) 意义下计算贡献,但要注意端点顺序可能相反,要分类处理,可以用树状数组维护。
时间复杂度 \(O(n\log n)\)
空间复杂度 \(O(n)\)
代码
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
template<class T>
struct Discretization {
vector<T> uniq;
Discretization() {}
Discretization(const vector<T> &src) { init(src); }
void init(const vector<T> &src) {
uniq = src;
sort(uniq.begin() + 1, uniq.end());
uniq.erase(unique(uniq.begin() + 1, uniq.end()), uniq.end());
}
int get(T x) { return lower_bound(uniq.begin() + 1, uniq.end(), x) - uniq.begin(); }
};
struct Query {
int op;
int x, l, r;
};
struct T {
ll sum;
static T e() { return { 0 }; }
T &operator+=(const T &x) { return sum += x.sum, *this; }
};
template<class T>
class Fenwick {
int n;
vector<T> node;
public:
Fenwick(int _n = 0) { init(_n); }
void init(int _n) {
n = _n;
node.assign(n + 1, T::e());
}
void update(int x, T val) { for (int i = x;i <= n;i += i & -i) node[i] += val; }
T query(int x) {
T ans = T::e();
for (int i = x;i >= 1;i -= i & -i) ans += node[i];
return ans;
}
};
int main() {
std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
int n, k;
cin >> n >> k;
if (n == 0) return cout << "fafa" << '\n', 0;
if (k == 0) {
vector<Query> q(n + 1);
vector<int> src(1);
for (int i = 1;i <= n;i++) {
int op;
cin >> op;
if (op == 1 || op == 2) {
int l, r;
cin >> l >> r;
l++, r++;
q[i] = { op,-1,l,r };
src.push_back(l);
src.push_back(r);
}
else {
int x;
cin >> x;
x++;
q[i] = { op,x,-1,-1 };
src.push_back(x);
}
}
Discretization<int> dc(src);
Fenwick<T> fw(dc.uniq.size());
for (int i = 1;i <= n;i++) {
auto [op, x, l, r] = q[i];
if (op == 1) fw.update(dc.get(l), { 1 }), fw.update(dc.get(r) + 1, { -1 });
else if (op == 2) fw.update(dc.get(l), { -1 }), fw.update(dc.get(r) + 1, { 1 });
else cout << fw.query(dc.get(x)).sum << '\n';
}
}
else {
Fenwick<T> fw(k + 1);
for (int i = 1;i <= n;i++) {
int op;
cin >> op;
if (op == 1) {
int l, r;
cin >> l >> r;
if (r - l + 1 >= k) fw.update(1, { 1 }), fw.update(k + 1, { -1 });
else {
l %= k;
r %= k;
l++, r++;
if (l <= r) fw.update(l, { 1 }), fw.update(r + 1, { -1 });
else fw.update(l, { 1 }), fw.update(k + 1, { -1 }), fw.update(1, { 1 }), fw.update(r + 1, { -1 });
}
}
else if (op == 2) {
int l, r;
cin >> l >> r;
if (r - l + 1 >= k) fw.update(1, { -1 }), fw.update(k + 1, { 1 });
else {
l %= k;
r %= k;
l++, r++;
if (l <= r) fw.update(l, { -1 }), fw.update(r + 1, { 1 });
else fw.update(l, { -1 }), fw.update(k + 1, { 1 }), fw.update(1, { -1 }), fw.update(r + 1, { 1 });
}
}
else {
int x;
cin >> x;
x %= k;
x++;
cout << fw.query(x).sum << '\n';
}
}
}
return 0;
}
NC21125 践踏的更多相关文章
- 牛客OI周赛6-提高组 B 践踏
践踏 思路: 如果k不为0, 那么就是对k取模意义下的区间更新, 单点查询 否则, 就是普通的区间更新, 单点查询 代码: #pragma GCC optimize(2) #pragma GCC op ...
- 用 jQuery.ajaxSetup 实现对请求和响应数据的过滤
不知道同学们在做项目的过程中有没有相同的经历呢?在使用 ajax 的时候,需要对请求参数和响应数据进行过滤处理,比如你们觉得就让请求参数和响应信息就这么赤裸裸的在互联网里来回的穿梭,比如这样: 要知道 ...
- .NET WebAPI 用ActionFilterAttribute实现token令牌验证与对Action的权限控制
项目背景是一个社区类的APP(求轻吐...),博主主要负责后台业务及接口.以前没玩过webAPI,但是领导要求必须用这个(具体原因鬼知道),只好硬着头皮上了. 最近刚做完权限这一块,分享出来给大家.欢 ...
- php 远程本地化无后缀图片
$body = '<p style="margin: 0px 0px 1.1em; padding: 0px; color: rgb(51, 51, 51); font-family: ...
- iOS之应用发布中的一些细节
Bundle identifier Xcode中 Target -> General中的bundle identifier ; info.plist中的Bundle identifier; 证书 ...
- 前端小知识(转载http://www.cnblogs.com/Wayou/p/things_you_dont_know_about_frontend.html)
前端已经被玩儿坏了!像console.log()可以向控制台输出图片等炫酷的玩意已经不是什么新闻了,像用||操作符给变量赋默认值也是人尽皆知的旧闻了,今天看到Quora上一个帖子,瞬间又GET了好多前 ...
- 不同json如何使用jsonArray以及ajax如何取,实现读取新闻
jsp界面 <%@ page contentType="text/html;charset=gb2312"%><%@page import="org.j ...
- Timberwolves forward Kevin Garnett to retire _洛杉矶时报
Timerwolves:森林狼队,forward:前锋; kevin Garnett,the best player in Minnesota Timberwolves history,is expe ...
- 偶的《javascript框架设计》终于出版
#cnblogs_post_body p{ text-indent:2em!important; } 历时两年多,我的书终于付梓出版了.应各方面的要求,写软文一篇,隆重介绍一下此书对各位程序员的钱途有 ...
- 冷门JS技巧
前端已经被玩儿坏了!像console.log()可以向控制台输出图片等炫酷的玩意已经不是什么新闻了,像用||操作符给变量赋默认值也是人尽皆知的旧闻了,今天看到Quora上一个帖子,瞬间又GET了好多前 ...
随机推荐
- 【Git】如何在github上提交PR(Pull Request)
[来源]https://mp.weixin.qq.com/s/yHQRjpVeZVV4PuoUKM0FSw
- .Net 使用 MongoDB
1.安装nuget包 MongoDB.Driver 2.简单代码 using MongoDB.Bson; using MongoDB.Driver; using System.Buffers; usi ...
- SQLServer数据库优化学习-总结
SQLServer数据库优化学习-总结 背景 各种能力都需要提升. 最近总是遇到SQLServer的问题 趁着周末进行一下学习与提高. 安装与优化 1. 数据库必须安装 64位, 不要安装成32位的版 ...
- Oracle19c 单节点ASM 存储模式数据库实例搭建过程
1. 建议使用OEL进行安装. 2. 可以优先在Oracle的yum上面下载必须的rpm包. 地址为: http://yum.oracle.com/repo/OracleLinux/OL7/lates ...
- mysql 获取 今天是今年的第几天, 以及 还有多少天元旦的方法
1. 获取今天是这一年的第几天 select dayofyear(curdate()); 或者是 select dayofyear(now()); 2. 获取还有多少天元旦的方法 select dat ...
- StorageClass 简单学习
StorageClass 简单学习 学习资料来源 https://www.jianshu.com/p/5e565a8049fc https://zhuanlan.zhihu.com/p/2895019 ...
- SUBMIT指定用户名错误
1.SUBMIT说明 在ABAP中,SUBMIT关键字用于运行另一个ABAP程序.通过SUBMIT关键字,可以在当前程序内部调用其他程序,而无需关闭当前程序. SUBMIT语句的一般语法如下: &qu ...
- linux中如何统计千万个文件总和
很简单.很简单.很简单.重要事情说三遍 命令:ls | grep '匹配信息' | wc -l ls查看该目录下的所有文件,果然隐藏文件也要匹配上的话,需要:ls -a grep匹配,如查看文件中有. ...
- Docker容器基础入门认知-Namespce
在使用 docker 之前我一般都认为容器的技术应该和虚拟机应该差不多,和虚拟机的技术类似,但是事实上容器和虚拟机根本不是一回事. 虚拟机是将虚拟硬件.内核(即操作系统)以及用户空间打包在新虚拟机当中 ...
- elementui 的tabs组件出现蓝色边框问题
elementui 的tabs组件出现蓝色边框问题 /deep/ .el-tabs__item:focus.is-active.is-focus:not(:active) { -webkit-box- ...