题目大意:对于一个不完全二分图,根节点为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. Kotlin中功能操作与集合(KAD 11)

    作者:Antonio Leiva 时间:Feb 2, 2017 原文链接:https://antonioleiva.com/functional-operations-collections-kotl ...

  2. NGUI-Tweens

    Tweens(补间动画) 补间动画有很多种: 这里以Tween Height为例: 项目层次: btn为一个按钮,group为一组图片精灵,预览图如下: 第一步:先为每个item附加一个Tween H ...

  3. Entity Framework(三)---FluentAPI和增删查改

    一.FluentAPI: 1.基本配置: namespace ConsoleApp14.ModelConfig { public class PersonConfig: EntityTypeConfi ...

  4. sql 游标使用

    declare @PASSDate datetime,@VLPN varchar(50),@VLPNColor varchar(10),@nambers int set @VLPN='';set @V ...

  5. Python MySQLdb 模块使用方法

    import MySQLdb 2.和数据库建立连接 conn=MySQLdb.connect(host="localhost",user="root",pass ...

  6. OpenFlow-Enaling innvation in Campus Networks

    OpenFlow-Enaling innvation in Campus Networks 出现问题 背景 Networks have become part of the critical infr ...

  7. js 图片自动循环切换setInterval();

    stlye样式定义 <style type="text/css">             body{background-image: url(img/001.jpg ...

  8. jquery select chosen禁用某一项option

    $("#tbParBudCode").chosen().change(function () { $("#tbParBudCode option[value='" ...

  9. Java实现身份证号码校验

    二话不说,直接上代码. package hope.identitycodecheck.demo; import java.text.DateFormat; import java.text.Simpl ...

  10. 【bzoj3144】[Hnoi2013]切糕 网络流最小割

    题目描述 输入 第一行是三个正整数P,Q,R,表示切糕的长P. 宽Q.高R.第二行有一个非负整数D,表示光滑性要求.接下来是R个P行Q列的矩阵,第z个 矩阵的第x行第y列是v(x,y,z) (1≤x≤ ...