算法学习分析-点分治 HDU 6269 Master of Subgraph
首先给出定义
点分治是一种处理树上路径的工具
挂出一道题目来:Master of Subgraph
这道题目让你求所有联通子图加和所能产生数字,问你1到m之间,那些数字可以被产生
这道题目,假如我们利用暴力的方法去求解的话
实际上是对每个节点进行一次dfs,这样的话会发现复杂度为O(N^2)也就是再9e6左右,再加上常数M/64,复杂度根本不够(9e9)
我们可以利用点分治去优化复杂度
点分治的原理就是树上的路径产生的答案,不是在经过这个节点的就是在不经过这个节点的,那我们找到树的重心的话,就能够算出来经过该点的所有答案,然后依次递归大约logN层,这样复杂度就变成了NlogN的程度,也就是3e4*1e3=3e7加上常数,再加上时间的宽限,完全够用
所以点分治就是树上分治的一种,减小重复计算的东西,不断逐步缩小子树的计算
其中一般来说要开 一个父节点数组,一个儿子数数组,来计算重心的位置
然后就是点分治,跟递归差不多就是要去计算答案
然后就是利用solve函数,每次点分治计算树根,然后依次处理子树的重心节点然后继续递归继续分治
#include <iostream>
#include <cstring>
#include <vector>
#include <bitset>
;
;
int E[MAXN][MAXN];
int all[MAXN];
int f[MAXN],son[MAXN],root,tot;
/*
分别代表f[x]的两侧孩子数目的最大值,重心的孩子数目最小
son代表以x为根的孩子数目
root是被移动的根
tot是当前根的孩子总数
*/
bool vis[MAXN];
std::bitset<MAXM>b[MAXN],ans;
int n,m,val[MAXN];
void dfs(int x,int fa){
/* dfs搜索树,将根移动到树的重心,降低dp层数 */
f[x] = ;
/* 标记孩子数目为0 */
son[x] = ;
/* 计算孩子数目 */
; i <= all[x]; i++)
{
int y=E[x][i];
if(!vis[y] && y!=fa)
{
dfs(y,x);
/* 递归进入子数 */
f[x] = std::max(f[x],son[y]);
/* 计算子树中孩子数目最多的子树孩子数 */
son[x]+=son[y];
/* 累加孩子数目 */
}
}
f[x]=std::max(f[x],tot-f[x]);
/* 计算该根节点最大孩子数其余侧的数目中两边的最大值 */
if(f[x]<f[root]) root=x;
/* 移动根节点,寻找重心 */
}
void getdp(int x, int fa){
b[x]<<=val[x];
/* 累加val[x] */
son[x]=;
;i<=all[x];i++)
{
int y=E[x][i];
if(!vis[y] && y!=fa)
{
b[y]=b[x];
getdp(y,x);
son[x]+=son[y];
b[x]|=b[y];
}
}
}
void solve(int x){
vis[x] = true;
b[x] = ;
getdp(x,);
/* 以某一点为根进行点分治 */
ans|=b[x];
/* 累加答案 */
;i<=all[x];i++)
{
/* 子树递归进行点分治 */
int y=E[x][i];
if(!vis[y])
{
tot = son[y];
root = ;
dfs(y,x);
/* 先寻找树根 */
solve(root);
/* 递归分治 */
}
}
}
int main(){
int T;
std::cin>>T;
while(T--)
{
scanf("%d%d",&n,&m);
;i<=n;i++) all[i]=;
ans.reset();
memset(vis,,sizeof(vis));
;i<n;i++)
{
int x,y;
scanf("%d%d",&x,&y);
E[x][++all[x]]=y;
E[y][++all[y]]=x;
}
;i<=n;i++)
{
scanf("%d",&val[i]);
}
f[] = n+;
tot=n;
dfs(,root);
solve(root);
;i<=m;i++)
{
printf("%d",(int)ans[i]);
}
puts("");
}
;
}
算法学习分析-点分治 HDU 6269 Master of Subgraph的更多相关文章
- HDU 6268 Master of Subgraph (2017 CCPC 杭州 E题,树分治 + 树上背包)
题目链接 2017 CCPC Hangzhou Problem E 题意 给定一棵树,每个点有一个权值,现在我们可以选一些连通的点,并且把这点选出来的点的权值相加,得到一个和. 求$[1, m] ...
- hdu 6268 Master of Subgraph(点分治+bitset)
You are given a tree with n nodes. The weight of the i-th node is wi. Given a positive integer m, no ...
- <2014 05 09> Lucida:我的算法学习之路
[转载] 我的算法学习之路 关于 严格来说,本文题目应该是我的数据结构和算法学习之路,但这个写法实在太绕口——况且CS中的算法往往暗指数据结构和算法(例如算法导论指的实际上是数据结构和算法导论),所以 ...
- 算法学习之C语言基础
算法学习,先熟悉一下C语言哈!!! #include <conio.h> #include<stdio.h> int main(){ printf(+); getch(); ; ...
- Python之路,Day21 - 常用算法学习
Python之路,Day21 - 常用算法学习 本节内容 算法定义 时间复杂度 空间复杂度 常用算法实例 1.算法定义 算法(Algorithm)是指解题方案的准确而完整的描述,是一系列解决问题的 ...
- 二次剩余Cipolla算法学习笔记
对于同余式 \[x^2 \equiv n \pmod p\] 若对于给定的\(n, P\),存在\(x\)满足上面的式子,则乘\(n\)在模\(p\)意义下是二次剩余,否则为非二次剩余 我们需要计算的 ...
- 算法学习之快速排序的C语言实现
近几天在学习简单算法,今天看了一个快速排序和堆排序,堆排序还没搞懂,还是先把快速排序搞清楚吧 教程网上一艘一大堆,这里选择一个讲的比较通俗的的一个吧: http://blog.csdn.net/mor ...
- 3.2_k-近邻算法案例分析
k-近邻算法案例分析 本案例使用最著名的”鸢尾“数据集,该数据集曾经被Fisher用在经典论文中,目前作为教科书般的数据样本预存在Scikit-learn的工具包中. 读入Iris数据集细节资 ...
- Reinforcement Learning Q-learning 算法学习-2
在阅读了Q-learning 算法学习-1文章之后. 我分析了这个算法的本质. 算法本质个人分析. 1.算法的初始状态是随机的,所以每个初始状态都是随机的,所以每个初始状态出现的概率都一样的.如果训练 ...
随机推荐
- 如何用Mendeley引用目标期刊要求的参考文献格式
如果我们要向目标的杂志期刊投稿,则需要采用该期刊的参考文献格式.我用的mendeley管理文献,不收费且使用方便.那么,我们如何用mendeley引用目标期刊的参考文献呢?以Applied energ ...
- Linux不停往外发包
一台Linux这两天不停往外发包,造成外部无法访问. [root@ct-nat ~]# watch ifconfig-------------查看数据包新增情况 Every 2.0s: ifconfi ...
- Velocity常用标签的讲解
Velocity是一个基于java的模板引擎(template engine).它允许任何人仅仅简单的使用模板语言(template language)来引用由java代码定义的对象. 当Veloci ...
- 宽字符wchar_t和窄字符char区别和相互转换
转自:http://blog.csdn.net/nodeathphoenix/article/details/7416725 1. 首先,说下窄字符char了,大家都很清楚,就是8bit表示的b ...
- Hander----使用
public class MainActivity extends Activity { private EditText UITxt; private Button updateUIBtn; pri ...
- [poj1459]Power Network(多源多汇最大流)
题目大意:一个网络,一共$n$个节点,$m$条边,$np$个发电站,$nc$个用户,$n-np-nc$个调度器,每条边有一个容量,每个发电站有一个最大负载,每一个用户也有一个最大接受量.问最多能供给多 ...
- [matlab]bp神经网络工具箱学习笔记
基本就三个函数: newff():创建一个bp神经网络 train():训练函数 sim():仿真函数 同时具有可视化界面,但目前不知道可视化界面如何进行仿真,且设置不太全 工具箱:Neural ne ...
- 【总结整理】关于IE6的兼容性
1. /*IE6兼容性,input边框border:none无效,不能去掉,只能把背景颜色去掉*/ background: none; /*background-color:#fff ;*/ 2. / ...
- 高级查询子条件查询filter
Filter Context 在查询过程中,只判断该文档是否满足条件,只有Yes或者No { "query":{ "bool":{ //布尔关键词 " ...
- This account is currently not available
今天在linux下切换用户发现提示This account is currently not available,说是无效用户了后来网上查了一下发现是用户的shell禁止登录了,解决方法只要开启she ...