Codeforces 1010D Mars rover
题目大意:对于一个不完全二分图,根节点为1,叶节点值为0或1,非叶节点包含一个操作(and,or,xor,not),求改变各个叶节点的值时(即0改为1,1改为0),根节点的值是多少
解法:遍历图求各节点的值,改变每个叶节点时,向图根节点遍历,求根节点值即可
有两个需要剪枝的地方,一,当改变到当前节点是该节点值已经不在改变,则结束图的向上递归
二,维护每个节点改变时,根节点的值,当再次遍历次节点时,可直接得到答案,结束递归
#include<iostream>
#include<cstdio>
#include<cmath>
#include<queue>
#include<vector>
#include<string.h>
#include<cstring>
#include<algorithm>
#include<set>
#include<map>
#include<fstream>
#include<cstdlib>
#include<ctime>
using namespace std;
#define scd(a) scanf("%d",&a)
#define scf(a) scanf("%lf",&a)
#define scl(a) scanf("%lld",&a)
#define sci(a) scanf("%I64d",&a)
#define scs(a) scanf("%s",a)
typedef long long ll;
const int desll[][]={{,},{,-},{,},{-,}};
const ll mod=1e9+;
const int maxn=1e6+;
const int maxm=1e8+;
const double eps=1e-;
int m,n,ar[maxn];
char ch[maxn];
int armid[maxn];
struct node{
int val,num;
char c;
node *pre,*l,*r;
void clear(){
l=r=NULL;
}
}no[maxn];
int ma,ans=;
int newCal(node* u)//求此节点的新值
{
if(u->c=='N') return -(u->l->val);
else if(u->c=='A') return u->l->val & u->r->val;
else if(u->c=='X') return u->l->val ^ u->r->val;
else if(u->c=='O') return u->l->val | u->r->val;
}
void dfs(node* u,int x)
{
int now=u->val;
u->val=x;
if(u->pre == NULL || now == x){//若此节点为根节点或此节点值已经不在改变,结束递归
ma=;
ans=no[].val;
}
else{
if(armid[u->num]!=-){//若此节点之前已经被便利过,则直接输出
ans = armid[u->num];//armid维护每个节点值改变时引起的根节点改变之后的值
ma=;
}
else{
dfs(u->pre,newCal(u->pre));
armid[u->num]=ans;
}
}
u->val=now;
} void init(node* u)
{
//cout<<u->val<<endl;
if(u->c=='I')return ;
init(u->l);
if(u->r!=NULL)init(u->r);
if(u->c=='N')u->val=-(u->l->val);
else if(u->c=='A')u->val = u->l->val & u->r->val;
else if(u->c=='X')u->val = u->l->val ^ u->r->val;
else if(u->c=='O')u->val = u->l->val | u->r->val;
}
int main()
{
scd(n);
int x,y;
no[].pre=NULL;
for(int i=;i<=n;i++)no[i].clear();
for(int i=;i<=n;i++){
scs(ch);scd(x);
if(ch[]=='A' || ch[]=='O' || ch[]=='X'){
scd(y);
no[i].l=&no[x];
no[i].r=&no[y];
no[x].pre = &no[i];
no[y].pre = &no[i];
no[i].c=ch[];
}
else if(ch[]=='N'){
no[i].l= &no[x];
no[x].pre = &no[i];
no[i].c=ch[];
}
else{
no[i].val=x;
no[i].c=ch[];
}
no[i].num=i;
}
memset(armid,-,sizeof(armid));
init(&no[]);
int len=;
for(int i=;i<=n;i++){
ma=;
if(no[i].c=='I'){
dfs(&no[i],-no[i].val);
ar[len++]=ans;
}
}
for(int i=;i<len;i++){
printf("%d",ar[i]);
}
printf("\n"); return ;
}
Codeforces 1010D Mars rover的更多相关文章
- CF1010D Mars rover [位运算,DP]
题目传送门 Mars Rover 格式难调,题面就不放了. 分析: 今天考试的时候考了这道题目的加强版,所以来做. 其实也并不难,我们建立好树形结构以后先把初始权值全部求出,然后就得到了根节点的初始值 ...
- codeforces 722E Research Rover
codeforces 722E Research Rover 题意 \(1e5*1e5\)的棋盘中有\(2000\)个坏点,初始给定一个值\(s(1<=s<=1e6)\).从棋盘左上角走到 ...
- CF1010D Mars rover
CF1010D Mars rover 洛谷评测传送门 题目描述 Natasha travels around Mars in the Mars rover. But suddenly it broke ...
- Codeforces Round #499 (Div. 1)部分题解(B,C,D)
Codeforces Round #499 (Div. 1) 这场本来想和同学一起打\(\rm virtual\ contest\)的,结果有事耽搁了,之后又陆陆续续写了些,就综合起来发一篇题解. B ...
- Codeforces Round #499 (Div. 1)
Codeforces Round #499 (Div. 1) https://codeforces.com/contest/1010 为啥我\(\rm Div.1\)能\(A4\)题还是\(\rm s ...
- [CF1010D]Mars Over_位运算性质
Mars rover 题目链接:http://codeforces.com/problemset/problem/1010/D 数据范围:略. 题解: 因为每次只改一个,改完之后改回去,这个性质很重要 ...
- L232 No methane on Mars
On earth, most of the methane in the atmosphere has been belched by living organisms, so finding the ...
- CodeForces Round #499 Div2
A: Stages 题意: 给你n个字符, 现在需要从中选取m个字符,每个字符的花费为在字母表的第几位,并且如果选了某个字符, 那么下一个选择的字符必须要在字母表的2位之后, 假如选了e 那么 不能选 ...
- hdu 3152 Obstacle Course
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=3152 Obstacle Course Description You are working on t ...
随机推荐
- USACO Section1.5 Prime Palindromes 解题报告
pprime解题报告 —— icedream61 博客园(转载请注明出处)--------------------------------------------------------------- ...
- Android FrameWork 概述
Framework是什么 Framework的中文意思是“框架”,在软件开发中通常指开发框架,在一个系统中处于内核层之上,为顶层应用提供接口,被设计用来帮助开发者快速开发顶层应用,而不必关心系统内核运 ...
- Python学习1,代码
看了好久的网上视频,今天尝试着写了一串代码: _author_ = "Happyboy" produce_list = [ ('Iphone',5800), ('Mac Pro ...
- operator、explicit与implicit
说这个之前先说下什么叫隐式转换和显示转换 1.所谓隐式转换,就是系统默认的转换,其本质是小存储容量数据类型自动转换为大存储容量数据类型. 例如:float f = 1.0: double d=f:这样 ...
- python之路——网络编程
一.楔子 你现在已经学会了写python代码,假如你写了两个python文件a.py和b.py,分别去运行,你就会发现,这两个python的文件分别运行的很好.但是如果这两个程序之间想要传递一个数据, ...
- [python] 网络数据采集 操作清单 BeautifulSoup、Selenium、Tesseract、CSV等
Python网络数据采集操作清单 BeautifulSoup.Selenium.Tesseract.CSV等 Python网络数据采集操作清单 BeautifulSoup.Selenium.Tesse ...
- Linux 查看当前日期和时间
一.查看和修改Linux的时区 1. 查看当前时区 命令 : "date -R" 2. 修改设置Linux服务器时区 方法 A 命令 : "tzselect" ...
- HDU 1937 F - Finding Seats 枚举
F - Finding Seats Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u S ...
- jQuery选择器之元素选择器
元素选择器:根据给定(html)标记名称选择所有的元素. 描述: $('element') 搜索指定元素标签名的所有节点,这是一个合集的操作.同样的也有原生方法getElementsByTagName ...
- DOM对象转化成jQuery对象
相比较jQuery转化成DOM,开发中更多的情况是把一个DOM对象加工成jQuery对象.$(参数)是一个多功能的方法,通过传递不同的参数而产生不同的作用. 如果传递给$(DOM)函数的参数是一个DO ...