Mars rover

题目链接http://codeforces.com/problemset/problem/1010/D

数据范围:略。


题解

因为每次只改一个,改完之后改回去,这个性质很重要。

发现有些叶子更改了之后,整体的答案是不变的,因为会出现:他的父亲是$\&$操作但是另一个儿子是$0$这种...

故此,我们先算出一个节点都不更改时,每个节点的值。

之后我们通过位运算,对每一个节点维护一个$tag$表示这个节点更改会不会影响到根节点。

遍历即可,细节可以看代码。

代码

#include <bits/stdc++.h>

#define N 1000010 

#define setIO(s) freopen(s".in", "r", stdin), freopen(s".out", "w", stdout) 

using namespace std;

char s[10];

int opt[N], val[N], ch[N][2];

bool tag[N];

char *p1, *p2, buf[100000];

#define nc() (p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 100000, stdin), p1 == p2) ? EOF : *p1 ++ )

int rd() {
int x = 0, f = 1;
char c = nc();
while (c < '0' || c > '9') {
if (c == '-')
f = -1;
c = nc();
}
while (c >= '0' && c <= '9') {
x = (((x << 2) + x) << 1) + (c ^ 48), c = nc();
}
return x * f;
} void dfs(int p) {
int ls = ch[p][0], rs = ch[p][1];
if (opt[p] == 1) {
return;
}
else if (opt[p] == 2) {
dfs(ch[p][0]);
val[p] = !val[ls];
}
else if (opt[p] == 3) {
dfs(ls), dfs(rs);
val[p] = val[ls] ^ val[rs];
}
else if (opt[p] == 4) {
dfs(ls), dfs(rs);
val[p] = val[ls] & val[rs];
}
else {
dfs(ls), dfs(rs);
val[p] = val[ls] | val[rs];
}
} void dfs2(int p) {
int ls = ch[p][0], rs = ch[p][1];
if (!tag[p]) {
if (ls) {
tag[ls] = false;
}
if (rs) {
tag[rs] = false;
}
}
else {
if (opt[p] == 1) {
return;
}
else if (opt[p] == 2) {
tag[ls] = true;
}
else if (opt[p] == 3) {
tag[ls] = tag[rs] = true;
}
else if (opt[p] == 5) {
tag[ls] = (val[rs] ? false : true);
tag[rs] = (val[ls] ? false : true);
}
else {
tag[ls] = (val[rs] ? true : false);
tag[rs] = (val[ls] ? true : false);
}
}
if (ls) {
dfs2(ls);
}
if (rs) {
dfs2(rs);
}
} int main() {
// setIO("b");
memset(tag, true, sizeof tag);
int n = rd();
/*
1 -> IN
2 -> Not
3 -> Xor
4 -> And
5 -> Or
*/
for (int i = 1; i <= n; i ++ ) {
char c = nc();
while (c != 'I' && c != 'N' && c != 'X' && c != 'A' && c != 'O') {
c = nc();
}
if (c == 'I') {
val[i] = rd();
opt[i] = 1;
}
else if (c == 'N') {
ch[i][0] = rd();
opt[i] = 2;
}
else if (c == 'X') {
ch[i][0] = rd(), ch[i][1] = rd();
opt[i] = 3;
}
else if (c == 'A') {
ch[i][0] = rd(), ch[i][1] = rd();
opt[i] = 4;
}
else {
ch[i][0] = rd(), ch[i][1] = rd();
opt[i] = 5;
}
}
// for (int i = 1; i <= n; i ++ ) {
// printf("%d ", opt[i]);
// }
// puts(""); dfs(1);
// for (int i = 1; i <= n; i ++ ) {
// printf("%d", val[i]);
// }
// puts(""); dfs2(1);
// for (int i = 1; i <= n; i ++ ) {
// if (tag[i]) {
// putchar('1'), putchar(' ');
// }
// else {
// putchar('0'), putchar(' ');
// }
// } for (int i = 1; i <= n; i ++ ) {
if (opt[i] == 1) {
if (val[1] ^ tag[i]) {
putchar('1');
}
else {
putchar('0');
}
}
}
fclose(stdin), fclose(stdout);
return 0;
}

[CF1010D]Mars Over_位运算性质的更多相关文章

  1. CF1010D Mars rover [位运算,DP]

    题目传送门 Mars Rover 格式难调,题面就不放了. 分析: 今天考试的时候考了这道题目的加强版,所以来做. 其实也并不难,我们建立好树形结构以后先把初始权值全部求出,然后就得到了根节点的初始值 ...

  2. Codeforces Round #499 (Div. 2) F. Mars rover_dfs_位运算

    题解: 首先,我们可以用 dfsdfsdfs 在 O(n)O(n)O(n) 的时间复杂度求出初始状态每个点的权值. 不难发现,一个叶子节点权值的取反会导致根节点的权值取反当且仅当从该叶子节点到根节点这 ...

  3. AcWing:143. 最大异或对(01字典树 + 位运算 + 异或性质)

    在给定的N个整数A1,A2……ANA1,A2……AN中选出两个进行xor(异或)运算,得到的结果最大是多少? 输入格式 第一行输入一个整数N. 第二行输入N个整数A1A1-ANAN. 输出格式 输出一 ...

  4. js中的位运算

    按位运算符是把操作数看作一系列单独的位,而不是一个数字值.所以在这之前,不得不提到什么是"位": 数值或字符在内存内都是被存储为0和 1的序列,每个0和1被称之为1个位,比如说10 ...

  5. JavaScript 位运算总结&拾遗

    最近补充了一些位运算的知识,深感位运算的博大精深,此文作为这个系列的总结篇,在此回顾下所学的位运算知识和应用,同时也补充下前文中没有提到的一些位运算知识. 把一个数变为大于等于该数的最小的2的幂 一个 ...

  6. leetcode - 位运算题目汇总(上)

    最近在看位运算的知识,十分感叹于位运算的博大精深,正好leetcode有 Bit Manipulation 的专题,正好拿来练练手. Subsets 给出一个由不同的数字组成的数组,枚举它的子数组(子 ...

  7. 位运算 ZOJ 3870 Team Formation

    题目传送门 /* 题意:找出符合 A^B > max (A, B) 的组数: 位运算:异或的性质,1^1=0, 1^0=1, 0^1=1, 0^0=0:与的性质:1^1=1, 1^0=0, 0^ ...

  8. C语言基础知识--位运算

    1.原码,反码,补码: (1)在n位的机器数中,最高位为符号位,该位为零表示为正,为一表示为负:其余n-1位为数值位,各位的值可为零或一.当真值为正时,原码.反码.补码数值位 完全相同:当真值为负时, ...

  9. 位运算总结&拾遗

    JavaScript 位运算总结&拾遗 最近补充了一些位运算的知识,深感位运算的博大精深,此文作为这个系列的总结篇,在此回顾下所学的位运算知识和应用,同时也补充下前文中没有提到的一些位运算知识 ...

随机推荐

  1. sql server 函数学习

    sql server 创建函数 资料 https://docs.microsoft.com/zh-cn/sql/relational-databases/user-defined-functions/ ...

  2. 2018-2019 ACM-ICPC, Asia Jiaozuo Regional Contest

    目录 Contest Info Solutions A. Xu Xiake in Henan Province D. Keiichi Tsuchiya the Drift King E. Resist ...

  3. 修改quartus 配置rom时memory很小的问题。

    我用的是quartus ii 13版本的仿真软件,在做VGA实验时显示用到640*480的图片所以就需要307200*1bit的rom.但是坑爹的megawizard- plug-in-manager ...

  4. sigprocmask , sigpending 和 sigsuspend函数

    转自 http://blog.csdn.net/elbort/article/details/7594772 sigprocmask函数:功能描述:设定对信号屏蔽集内的信号的处理方式(阻塞或不阻塞). ...

  5. 【CTS2019】珍珠【生成函数,二项式反演】

    题目链接:洛谷 pb大佬说这是sb题感觉好像有点过fan...(我还是太弱了) 首先,设$i$这个数在序列中出现$a_i$次,要求$\sum_{i=1}^D[a_i \ mod \ 2]\leq n- ...

  6. Selenium处理授权框,登录框,握手框

    在Web自动化中,常常遇到三种弹框: JavaScript警告框,如alert,confirm,prompt等,如下图: 处理方法为driver.switch_to.alert().dismiss() ...

  7. csp-s模拟测试112 & csp-s模拟测试113

    考前两天模拟. Day1直接炸飞,T1浪费的时间太长,对拍+调试了一个多小时但复杂度还不能过,最后5分钟想出来了解决方案但是已经打不出来了.T2读入出了事故RE0.T3打了假贪心. Day2心态几乎也 ...

  8. Ubuntu18.04上安装N卡驱动、CUDA、CUDNN三连

    环境:Ubuntu18.04 显卡驱动真的挺方便的,CUDA和CUDNN还是踩了一些坑2333 1.安装显卡驱动 安装ubuntu更新或sudo apt-get update & sudo a ...

  9. [oracle]TX行锁发生的常见场景(转贴)

    TX行锁发生的常见场景: 1.当前会话要更新或删除的记录,已经被其他会话更新或删除. 2.对于表上有唯一索引的情况,多个会话插入或更新为相同的键值. 3.对于表上有位图索引的情况,多个会话即使更新不同 ...

  10. vue开发(一)安装

    1.安装nodejshttps://nodejs.org/zh-cn/ 2.vs2019  工具-获取工具和功能 勾选nodejs开发并安装 3.新建基于vuejs web应用程序 4.右键项目在此处 ...