题目大意:对于一个不完全二分图,根节点为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的更多相关文章

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

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

  2. codeforces 722E Research Rover

    codeforces 722E Research Rover 题意 \(1e5*1e5\)的棋盘中有\(2000\)个坏点,初始给定一个值\(s(1<=s<=1e6)\).从棋盘左上角走到 ...

  3. CF1010D Mars rover

    CF1010D Mars rover 洛谷评测传送门 题目描述 Natasha travels around Mars in the Mars rover. But suddenly it broke ...

  4. Codeforces Round #499 (Div. 1)部分题解(B,C,D)

    Codeforces Round #499 (Div. 1) 这场本来想和同学一起打\(\rm virtual\ contest\)的,结果有事耽搁了,之后又陆陆续续写了些,就综合起来发一篇题解. B ...

  5. Codeforces Round #499 (Div. 1)

    Codeforces Round #499 (Div. 1) https://codeforces.com/contest/1010 为啥我\(\rm Div.1\)能\(A4\)题还是\(\rm s ...

  6. [CF1010D]Mars Over_位运算性质

    Mars rover 题目链接:http://codeforces.com/problemset/problem/1010/D 数据范围:略. 题解: 因为每次只改一个,改完之后改回去,这个性质很重要 ...

  7. L232 No methane on Mars

    On earth, most of the methane in the atmosphere has been belched by living organisms, so finding the ...

  8. CodeForces Round #499 Div2

    A: Stages 题意: 给你n个字符, 现在需要从中选取m个字符,每个字符的花费为在字母表的第几位,并且如果选了某个字符, 那么下一个选择的字符必须要在字母表的2位之后, 假如选了e 那么 不能选 ...

  9. hdu 3152 Obstacle Course

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=3152 Obstacle Course Description You are working on t ...

随机推荐

  1. DOS程序员手册(八)

    备,就可以从程序中访问驱动程序.可以用句柄功能调用来     打开设备(见列表12.9)         列表12.9           /*example.C               List ...

  2. 在iis上部署asp.net mvc2.0

    mvc2.0是vs2010自带的,在开发环境下可以直接部署在iis中.在生产环境下,如果不能找到正确的mvc2.0版本,可以直接把开发环境下的System.Web.Mvc.dll拷贝过去使用. 1,  ...

  3. python2.7写入文件时指定编码为utf-8

    python3.0可以这样写 f = open('ufile.log', 'w', 'utf-8')   但在python2.7中open()没有编码参数,如上那样写会报错,可以使用如下模块 impo ...

  4. NGUI-UIProgressBar,UIScrollBar,UISlider

    UIProgressBar是UIScrollBar和UISlider的基类 1.先来看下UIProgressBar(进度条)的使用 层次: progressBar的Inspector视图: 而fore ...

  5. Linux系统源码安装cloud-init

    参考:https://cloud.tencent.com/document/product/213/12587使用以下命令下载 cloud-init 源码包 官网下载地址:https://launch ...

  6. Python——数据类型之list、tuple

    本篇主要内容 •  list初识 •  list元素的访问 •  list内部所有的方法 •  tuple介绍和与list用法的比较 我觉得Python里面用的最多的就是List了,感觉好强大.他能存 ...

  7. Linux下vsftp匿名用户配置

    Linux下vsftp匿名用户上传和下载的配置 配置要注意三部分,请一一仔细对照: 1.vsftpd.conf文件的配置(vi /etc/vsftpd/vsftpd.conf) #允许匿名用户登录FT ...

  8. HDU 4661 Message Passing ( 树DP + 推公式 )

    参考了: http://www.cnblogs.com/zhsl/archive/2013/08/10/3250755.html http://blog.csdn.net/chaobaimingtia ...

  9. vb如何将数据库中某个字段显示在一个文本框

    Dim mrc As ADODB.Recordset Private Sub cmdQuery_Click() Dim txtSQL As String Dim MsgText As String t ...

  10. 第十二篇:HTML基础

    本篇内容 HTML概述 HTML常用基本标签 CSS格式引入 一. HTML概述 1.定义: HTML,超文本标记语言,写给浏览器的语言,目前网络上应用最广泛的语言.HTML也在不断的更新,最新版本已 ...