Description

题库链接

P 博士将他的计算任务抽象为对一个整数的操作。

具体来说,有一个整数 \(x\) ,一开始为 \(0\) 。

接下来有 \(n\) 个操作,每个操作都是以下两种类型中的一种:

  • 1 a b :将 \(x\) 加上整数 \(a\cdot 2^b\) ,其中 \(a\) 为一个整数, \(b\) 为一个非负整数
  • 2 k :询问 \(x\) 在用二进制表示时,位权为 \(2^k\) 的位的值(即这一位上的 \(1\) 代表 \(2^k\) )

保证在任何时候, \(x\geqslant 0\) 。

\(1\leq n\leq 10^6,|a| \leq 10^9,0 \leq b, k \leq 30n\)

Solution

考虑稍微暴力一点的做法,我们开两个数组来模拟进位(一个是 \(a > 0\) ,另一个 \(a < 0\) )。

然后对于询问,我们假设小于 \(k\) 位的部分 \(a>0\) 的是 \(s_1\) , \(a<0\) 的是 \(s_2\) 。

讨论所有情况,我们可以得出结论:

  • 若 \(s_1\geq s2\) ,输出答案为 \([x\oplus y]\) ,其中 \(x\) 是 \(a>0\) 的第 \(k\) 位的值, \(y\) 是 \(a<0\) 的第 \(k\) 位的值。
  • 若 \(s_1< s2\) ,输出答案为 \([x=y]\) 。

这样总复杂度是 \(O(30n\log(30n))\) 的。

考虑优化。

直接拿 \(\text{zkw线段树}\) 卡过去啦!

Code

#include <bits/stdc++.h>
using namespace std;
const int M = 1000000*30+300;
void gi(int &x) {
char ch = getchar(); x = 0; int flag = 0;
for (; ch < '0' || ch > '9'; ch = getchar()) flag |= (ch == '-');
for (; ch >= '0' && ch <= '9'; ch = getchar()) x = (x<<1)+(x<<3)+ch-48;
if (flag) x = -x;
} int s1[M], s2[M], tr[(1<<26)+5];
int n, N, rbsc, opt, a, b, lst[32], bin[32], tot; void modify(int *s, int a, int b) {
tot = 0;
for (int i = 30; i >= 0 && a; i--)
if (bin[i]&a) lst[++tot] = i, a -= bin[i];
int r = lst[1]+b, l = lst[tot]+b;
for (int i = 1; i <= tot; i++) {
int loc = lst[i]+b;
while (s[loc]) s[loc++] = 0;
r = max(r, loc), s[loc] = 1;
}
for (int i = l; i <= r; i++) tr[N+i] = (s1[i]^s2[i]);
for (l = (l+N)>>1, r = (r+N)>>1; l; l >>= 1, r >>= 1)
for (int j = l; j <= r; j++) tr[j] = tr[j<<1]|tr[j<<1|1];
}
int query(int a) {
for (a += N; a; a >>= 1)
if (a&1&tr[a^1]) {
for (a ^= 1; a < N; a = a<<1|tr[a<<1|1]);
return a-N;
}
return -1;
}
void work() {
gi(n); gi(rbsc), gi(rbsc), gi(rbsc);
for (N = 1; N <= n*30; N <<= 1);
bin[0] = 1; for (int i = 1; i <= 30; i++) bin[i] = (bin[i-1]<<1);
while (n--) {
gi(opt);
if (opt == 1) {
gi(a), gi(b);
if (a < 0) modify(s2, -a, b);
else modify(s1, a, b);
}else {
gi(a); int now = query(a);
if (now == -1 || s1[now] > s2[now]) putchar('0'+(s1[a]^s2[a]));
else putchar('0'+(s1[a] == s2[a]));
putchar('\n');
}
}
}
int main() {work(); return 0; }

[NOI 2017]整数的更多相关文章

  1. NOI 2017 整数(线段树)

    题意 https://loj.ac/problem/2302 思路 拆分成每个二进制位的加减来考虑,维护那个整数的二进制位.不难发现,进位就是找右边第一个 \(0\) 的位置,并将其赋值为 \(1\) ...

  2. NOI 2017滚粗退役记

    NOI 2017 游记 又到了OIer退役了的季节 Day -1 今天是报到日. 中午11点多的动车.动车上和dick32165401和runzhe2000谈笑风生.顺便用dick32165401的流 ...

  3. 【NOI】2017 整数(BZOJ 4942,LOJ2302) 压位+线段树

    [题目]#2302. 「NOI2017」整数 [题意]有一个整数x,一开始为0.n次操作,加上a*2^b,或询问2^k位是0或1.\(n \leq 10^6,|a| \leq 10^9,0 \leq ...

  4. NOI 2017 Day1 题解

    被虐爆了... T1 整数 题目传送门 Description 有一个整数 \(x\),有 \(n\) 此操作,每次操作为以下两种情况: 给出 \(a,b\),将 \(x\) 加上 \(a\times ...

  5. [NOI 2017]蔬菜

    Description 题库链接 小 N 是蔬菜仓库的管理员,负责设计蔬菜的销售方案. 在蔬菜仓库中,共存放有 \(n\) 种蔬菜,小 N 需要根据不同蔬菜的特性,综合考虑各方面因素,设计合理的销售方 ...

  6. [NOI 2017]游戏

    Description 题库链接 小 L 计划进行 \(n\) 场游戏,每场游戏使用一张地图,小 L 会选择一辆车在该地图上完成游戏. 小 L 的赛车有三辆,分别用大写字母 A.B.C 表示.地图一共 ...

  7. [NOI 2017]蚯蚓排队

    Description 题库链接 蚯蚓幼儿园有 \(n\) 只蚯蚓.幼儿园园长神刀手为了管理方便,时常让这些蚯蚓们列队表演. 所有蚯蚓用从 \(1\) 到 \(n\) 的连续正整数编号.每只蚯蚓的长度 ...

  8. (转)2-SAT小结

    2-sat小结 原文作者:老K 原文传送门 2-sat是什么 一类问题是这样的: (两个符号的意思 \(\lor \ or,\land \ and\)) 有n个布尔变量,现在对它们做出限制,比如\(a ...

  9. [转帖]亚马逊发布自主64核心ARM处理器:单核性能远超铂金至强

    亚马逊发布自主64核心ARM处理器:单核性能远超铂金至强 https://news.mydrivers.com/1/660/660383.htm 不知道真假 看样子比华为的鲲鹏920 要牛B . 亚马 ...

随机推荐

  1. Django Model模型的实战操作笔记

    Model模型的实战操作笔记 1. 创建数据库和表 进入MySQL数据库创建数据库:mytest 进入数据库创建数据表:mytest_users CREATE TABLE `mytest_users` ...

  2. 阿里巴巴Java开发规约插件安装使用指南

    编码规范插件安装使用指南 阿里技术公众号于今年的2月9日首次公布<阿里巴巴Java开发规约>,瞬间引起全民代码规范的热潮,后又发布了PDF的终极版,大家踊跃留言,期待配套的静态扫描工具开放 ...

  3. ubuntu 应用添加进环境变量

    BG:公司同事使用的电脑系统大多为windows ,有部分mac和Ubuntu(我就是那个部分Ubuntu),某些情况为了统一格式,便下载了一些解压即可使用的软件,但是每次点开文件夹然后点开程序很繁琐 ...

  4. TensorFlow基本--张量

    在TensorFlow中所有的数据都通过张量的形式表示,从功能上看张量可以被简单的理解为多维数据,其中零阶张量表示标量(一个数),第一阶张量为向量(一个一维数组),第n阶向量可以理解为一个n维数组. ...

  5. noip第20课资料

  6. html 基本用法

    html表单表格基本用法,直接贴代码. <html> <head> <title>html基础</title> </head> </b ...

  7. DDD简明入门之道 - 开篇

    DDD简明入门之道 - 开篇 犹豫了很久才写下此文,一怕自己对DDD的理解和实践方式有偏差,二怕误人子弟被贻笑大方,所以纰漏之处还望各位谅解.不啰嗦,马上进入正题,如果你觉得此文不错就点个赞吧. 概述 ...

  8. js截取字符串方法整理slice(), substr(), substring(), split()

      substr(start,length) stringObject.substr(start,length) //start,截取起始下标,-1 指字符串最后一个字符,-2 指倒数第二个字符开始 ...

  9. WebView 错误码整理

    在使用WebView中,我们不可避免的会接触到WebView加载失败的异常处理的需求,这时候,需要我们监听失败的方法也就是onReceivedError方法: public class CustomW ...

  10. apache环境之困扰,Rewrite导致无法加载多个不同的.html文件

    又是一个项目,为访问多个纯静态html页面h5游戏页,能够做一些简单分享和跳转即可.原本是一个简单得不能的项目,但是却多生了事端. 我按照apache的惯例,将文件上传到服务器的DocumentRoo ...