2015 Asia Singapore ICPC Contest J题

点击打开链接 提交地址


#include <iostream>
#include <string>
#include <string.h>
#include <math.h>
#include <cmath>
#include <stdio.h>
#include <vector>
#include <stdlib.h>
#include <algorithm>
#include <set>
using namespace std;

const int N = 300008 ;

struct E{
       int v ;
       int next ;
}e[N*2];

int egid ;
int g[N] ;

void add_edge(int u , int v){
     e[egid].v = v ;
     e[egid].next = g[u] ;
     g[u] = egid++ ;
}

int leftId[N] , rightId[N] ;
int dfsTime ;

void  dfs(int u , int fa){
      leftId[u] = ++dfsTime ;
      for(int i = g[u] ; i != -1 ; i = e[i].next){
           int v = e[i].v ;
           if(fa == v) continue ;
           dfs(v , u) ;
      }
      rightId[u] = dfsTime ;
}

int n ;

int lowbit(int x){
    return x & (-x) ;
}

typedef long long LL ;

LL  val[2][N] ;

void  add(int idx , LL c , int index){
      for(; idx <= n ; idx += lowbit(idx)) val[index][idx] ^= c ;
}

LL  sum(int idx , int index){
    LL res = 0  ;
    for(; idx >= 1 ; idx -= lowbit(idx)) res ^= val[index][idx] ;
    return res ;
}

LL  getSum(int l , int r , int index){
    if(l > r) return 0 ;
    return sum(r , index) ^ sum(l-1 , index) ;
}

void  init(){
      memset(g , -1 , sizeof(g)) ;
      memset(val , 0 , sizeof(val)) ;
      egid = 0 ;
      dfsTime = 0 ;
}

int color[N] ;

void addColor(int idx , int c){
      if(c < 50) add(idx , 1LL<<c , 0) ;
      else add(idx , 1LL<<(c-50) , 1) ;
}

int countbitsize(LL x){
    int sum = 0 ;
    while(x){
         if(x & 1) sum++ ;
         x >>= 1 ;
    }
    return sum ;
}

int  main(){
     int q , u , k , x  , res ;
     while(scanf("%d%d" , &n , &q) != EOF){

          init() ;

          for(int i = 1 ; i <= n ; i++){
             scanf("%d" , &color[i]) ;
             color[i]-- ;
          }

          for(int i = 2 ; i <= n ; i++){
              scanf("%d" , &u) ;
              add_edge(u , i) ;
              add_edge(i , u) ;
          }
          dfs(1 , -1) ;

          for(int i = 1 ; i <= n ; i++){
              addColor(leftId[i] , color[i]) ;
          }

          while(q--){
              scanf("%d%d" , &k , &x) ;
              if(k == 0){
                   if(x > n){
                       puts("0") ;
                       continue ;
                   }
                   LL a = getSum(leftId[x] , rightId[x] , 0) ;
                   LL b = getSum(leftId[x] , rightId[x] , 1) ;
                   res = countbitsize(a) + countbitsize(b) ;
                   printf("%d\n" , res) ;
              }
              else{
                  addColor(leftId[x] , color[x]) ;
                  color[x] = k - 1  ;
                  addColor(leftId[x] , color[x]) ;
              }
          }
     }

     return  0 ;
}


1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READme.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 、 1资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READmE.文件(md如有),本项目仅用作交流学习参考,请切勿用于商业用途。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值