热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

POJ3321深度优先搜索+树状数组

题意传送门POJ3321题解求树的dfsdfsdfs序,每棵子树dfsdfsdfs开始与结束的时间戳对应的区间,用BITBITBIT维护其苹果数量

题意

传送门 POJ 3321


题解

求树的 dfsdfsdfs 序&#xff0c;每棵子树 dfsdfsdfs 开始与结束的时间戳对应的区间&#xff0c;用 BITBITBIT 维护其苹果数量。一开始 vectorG[MAX_N]vector G[MAX\_N]vector<int>G[MAX_N] 存图 TLETLETLE&#xff0c;逛了逛 discussdiscussdiscuss &#xff0c;没想到 vector>Gvector> Gvector<vector<int>>G 才能过。

#include
#include
#include
#include
#include
#include
#include
#define min(a,b) (((a) <(b)) ? (a) : (b))
#define max(a,b) (((a) > (b)) ? (a) : (b))
#define abs(x) ((x) <0 ? -(x) : (x))
#define INF 0x3f3f3f3f
#define delta 0.85
using namespace std;#define MAX_N 100005
int bit[MAX_N &#43; 1], n;void add(int i, int x){while(i <&#61; n){bit[i] &#43;&#61; x;i &#43;&#61; i & -i;}
}int sum(int i){int s &#61; 0;while(i > 0){s &#43;&#61; bit[i];i -&#61; i & -i;}return s;
}int N, M, V, clk;
vector<vector<int>> G;
int L[MAX_N], R[MAX_N], apple[MAX_N];void dfs(int v, int f){&#43;&#43;clk;L[v] &#61; clk;for(int i &#61; 0; i < G[v].size(); i&#43;&#43;){int u &#61; G[v][i];if(u !&#61; f) dfs(u, v);}R[v] &#61; clk;
}void solve(){clk &#61; 0;dfs(1, 0);n &#61; N;for(int i &#61; 1; i <&#61; n; i&#43;&#43;){add(i, 1);apple[i] &#61; 1;}for(int i &#61; 0; i < M; i&#43;&#43;){char op;int x;scanf(" %c%d", &op, &x);if(op &#61;&#61; &#39;C&#39;){if(apple[x] & 1) add(L[x], -1);else add(L[x], 1);apple[x] ^&#61; 1;}else{printf("%d\n", sum(R[x]) - sum(L[x] - 1));}}
}int main(){while(~scanf("%d", &N)){V &#61; N;G &#61; vector<vector<int>> (N &#43; 1, vector<int>());for(int i &#61; 0; i < N - 1; i&#43;&#43;){int u, v;scanf("%d%d", &u, &v);G[u].push_back(v); G[v].push_back(u);}scanf("%d", &M);solve();}return 0;
}

推荐阅读
  • 寒假作业解析:第三周 2月12日 第7题
    尽快完成之前的练习任务!每日一练2.1 Problem A Laurenty and Shop 的题目要求是选择两条不同的路线以最小化总的等待时间。简要分析:通过对比不同路线的等待时间,可以找到最优解。此问题可以通过动态规划或贪心算法来解决,具体取决于路线的复杂性和约束条件。 ... [详细]
  • 在洛谷 P1344 的坏牛奶追踪问题中,第一问要求计算最小割,而第二问则需要找到割边数量最少的最小割。通过为每条边附加一个单位权值,可以在求解最小割时优先选择边数较少的方案,从而同时解决两个问题。这种策略不仅简化了问题的求解过程,还确保了结果的最优性。 ... [详细]
  • 蓝桥杯算法实战:节点选取策略优化分析
    本文针对蓝桥杯算法竞赛中的节点选取策略进行了深入分析与优化。通过对比不同节点选择方法的效果,提出了基于贪心算法和动态规划的综合优化方案,旨在提高算法效率和准确性。实验结果表明,该优化策略在处理大规模数据集时表现出色,显著提升了算法性能。 ... [详细]
  • 在解决区间相关问题时,我发现自己经常缺乏有效的思维方式,即使是简单的题目也常常需要很长时间才能找到解题思路,而一旦得到提示便能迅速理解。题目要求对一个包含n个元素的数组进行操作,并给出一个参数k,具体任务是…… ... [详细]
  • 在2019年寒假强化训练中,我们深入探讨了二分算法的理论与实践应用。问题A聚焦于使用递归方法实现二分查找。具体而言,给定一个已按升序排列且无重复元素的数组,用户需从键盘输入一个数值X,通过二分查找法判断该数值是否存在于数组中。输入的第一行为一个正整数,表示数组的长度。这一训练不仅强化了对递归算法的理解,还提升了实际编程能力。 ... [详细]
  • 经过两天的努力,终于成功解决了半平面交模板题POJ3335的问题。原来是在`OnLeft`函数中漏掉了关键的等于号。通过这次训练,不仅加深了对半平面交算法的理解,还提升了调试和代码实现的能力。未来将继续深入研究计算几何的其他核心问题,进一步巩固和拓展相关知识。 ... [详细]
  • NOIP2000的单词接龙问题与常见的成语接龙游戏有异曲同工之妙。题目要求在给定的一组单词中,从指定的起始字母开始,构建最长的“单词链”。每个单词在链中最多可出现两次。本文将详细解析该题目的解法,并分享学习过程中的心得体会。 ... [详细]
  • 洛谷 P4035 [JSOI2008] 球形空间生成器(高斯消元法 / 模拟退火算法)
    本文介绍了洛谷 P4035 [JSOI2008] 球形空间生成器问题的解决方案,主要使用了高斯消元法和模拟退火算法。通过这两种方法,可以高效地求解多维空间中的球心位置。文章提供了详细的算法模板和实现代码,适用于 ACM 竞赛和其他相关应用场景。数据范围限制在 10 以内,确保了算法的高效性和准确性。 ... [详细]
  • 本文详细介绍了在CodeUp平台中实现大数进制转换的技术方法。具体而言,该问题要求将一个最多包含30位数字的十进制非负整数转换为二进制表示。输入数据包含多行,每行包含一个不超过30位的十进制非负整数。通过高效的算法设计,确保了大数转换的准确性和性能。 ... [详细]
  • 本文深入探讨了佩尔方程 \( x^2 - dy^2 = 1 \) 的递推关系式。通过构造特定的矩阵并利用矩阵快速幂的方法,可以高效地计算出该方程的第 k 组解。此外,文章还详细分析了递推关系式的数学背景及其在数论中的应用,为相关研究提供了坚实的理论基础。 ... [详细]
  • 手指触控|Android电容屏幕驱动调试指南
    手指触控|Android电容屏幕驱动调试指南 ... [详细]
  • 本文对常见的字符串哈希函数进行了全面分析,涵盖了BKDRHash、APHash、DJBHash、JSHash、RSHash、SDBMHash、PJWHash和ELFHash等多种算法。这些哈希函数在不同的应用场景中表现出各异的性能特点,通过对比其算法原理、计算效率和碰撞概率,为实际应用提供了有价值的参考。 ... [详细]
  • 探索偶数次幂二项式系数的求和方法及其数学意义 ... [详细]
  • 解题心得:UVA1339(逻辑分析与字符串处理+排序算法)
    解题心得:UVA1339(逻辑分析与字符串处理+排序算法) ... [详细]
  • 单链表的高效遍历及性能优化策略
    本文探讨了单链表的高效遍历方法及其性能优化策略。在单链表的数据结构中,插入操作的时间复杂度为O(n),而遍历操作的时间复杂度为O(n^2)。通过在 `LinkList.h` 和 `main.cpp` 文件中对单链表进行封装,我们实现了创建和销毁功能的优化,提高了单链表的使用效率。此外,文章还介绍了几种常见的优化技术,如缓存节点指针和批量处理,以进一步提升遍历性能。 ... [详细]
author-avatar
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有