HDU 4605 Magic Ball Game (dfs+离线树状数组)
题意:给你一颗有根树,它的孩子要么只有两个,要么没有,且每个点都有一个权值w。
接着给你一个权值为x的球,它从更节点开始向下掉,有三种情况
x=w[now]:停在此点
x<w[now]:当有孩子时:1/2可能性到左孩子,1/2可能性到右孩子
x>w[now]:当有孩子时:1/8可能性到左孩子,7/8可能性到右孩子
再给你一个点U,问你从根节点到U结点的可能性为多少 7^x/2^y ,求出x y
题解:非常经典的一个题,我使用邻接表存储,接着使用dfs遍历,最后树状数组维护结果。
我们可以知道 1/2:y++ 1/8:y+=3 7/8:x++,y+=3
接着就是每次只需要找到唯一一条从根到U点父节点的所有权值
接着找:左孩子中小于X的个数,右孩子中小于X的个数,左孩子中大于X的个数,右孩子中大于X的个数,但是我们要注意一个情况就是当有等于X的时候就不能到达U
这样我们可以离线vector存储问题(同一个点不同则存在一起),从根节点开始dfs遍历每个点
当走孩子节点时就把此点的权值加入数组(开两个数组),回溯时删除此权值
在添加前就此点权值寻找上诉四个值,并利用树状数组维护
#include<set>
#include<map>
#include<queue>
#include<stack>
#include<cmath>
#include<vector>
#include<string>
#include<cstdio>
#include<cstring>
#include<stdlib.h>
#include<iostream>
#include<algorithm>
using namespace std;
#define eps 1E-8
/*注意可能会有输出-0.000*/
#define Sgn(x) (x<-eps? -1 :x<eps? 0:1)//x为两个浮点数差的比较,注意返回整型
#define Cvs(x) (x > 0.0 ? x+eps : x-eps)//浮点数转化
#define zero(x) (((x)>0?(x):-(x))<eps)//判断是否等于0
#define mul(a,b) (a<<b)
#define dir(a,b) (a>>b)
typedef long long ll;
typedef unsigned long long ull;
const int Inf=<<;
const double Pi=acos(-1.0);
const int Mod=1e9+;
const int Max=;//包括询问
int head[Max],nnext[Max],to[Max],chi[Max],e;//邻接表存树 dfs遍历
struct node
{
int val,poi;
} que[Max]; //问题
int dir[][]= {{,},{,},{,}}; //比x大的孩子 比x小的左孩子 比x小的右孩子
map<int,int> mp;//离散化
int val[Max];
vector<int> vec[Max];//存下这个点有哪些权值
int len[Max],ansx[Max],ansy[Max];
int nn;//总权值点
void Init(int n,int *lbit,int *rbit)
{
for(int i=; i<=n; ++i)
{
len[i]=;
ansx[i]=;
ansy[i]=;
head[i]=-;
vec[i].clear();
}
e=;
nn=;
mp.clear();
memset(lbit,,sizeof(lbit));
memset(rbit,,sizeof(rbit));
return;
}
void AddEdge(int u,int v,int ch)
{
nnext[e]=head[u];
to[e]=v;
chi[e]=ch;
head[u]=e++;
return;
}
int lowbit(int x)
{
return x&(-x);
}
void Add(int x,int y,int *bit)
{
while(x<=nn)
{
bit[x]+=y;
x+=lowbit(x);
}
return;
}
int Sum(int x,int *bit)
{
int sum=;
while(x)
{
sum+=bit[x];
x-=lowbit(x);
}
return sum;
}
int bit[][Max];//区分左右孩子
void dfs(int son,int tol1,int tol2)//遍历邻接表
{
int now=mp[val[son]];
for(int i=; i<len[son]; ++i)
{
int now1=mp[que[vec[son][i]].val];
int lef1=Sum(now1,bit[]);
int lef2=Sum(now1-,bit[]);
int rig1=Sum(now1,bit[]);
int rig2=Sum(now1-,bit[]);
if(lef1-lef2||rig1-rig2)
{
ansx[vec[son][i]]=-;
}
else//求值
{
ansx[vec[son][i]]=rig2*dir[][]; ansy[vec[son][i]]=(tol1-lef1)*dir[][];
ansy[vec[son][i]]+=(tol2-rig1)*dir[][];
ansy[vec[son][i]]+=lef2*dir[][];
ansy[vec[son][i]]+=rig2*dir[][];
}
}
for(int i=head[son]; ~i; i=nnext[i])
{
Add(now,,bit[chi[i]]);//加点
if(!chi[i])
dfs(to[i],tol1+,tol2);
else
dfs(to[i],tol1,tol2+);
Add(now,-,bit[chi[i]]);//删点
}
return;
}
int main()
{
int t,n,m,q;
int u,a,b;
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
Init(n,bit[],bit[]);
for(int i=; i<=n; ++i)
{
scanf("%d",&val[i]);
mp[val[i]]=;
}
scanf("%d",&m);
for(int i=; i<m; ++i)//邻接表
{
scanf("%d %d %d",&u,&a,&b);
AddEdge(u,a,);
AddEdge(u,b,);
}
scanf("%d",&q);
for(int i=; i<q; ++i)
{
scanf("%d %d",&que[i].poi,&que[i].val);
vec[que[i].poi].push_back(i);//根据树上某点存que小标
len[que[i].poi]++;
mp[que[i].val]=;
}
int cnt=;
for(map<int,int>::iterator it=mp.begin(); it!=mp.end(); ++it) //离散化
{
it->second=cnt++;
nn++;
}
dfs(,,);
for(int i=; i<q; ++i)
{
if(ansx[i]==-)
printf("0\n");
else
printf("%d %d\n",ansx[i],ansy[i]);
}
}
return ;
}
HDU 4605 Magic Ball Game (dfs+离线树状数组)的更多相关文章
- hdu 4605 Magic Ball Game (在线主席树/离线树状数组)
版权声明:本文为博主原创文章,未经博主允许不得转载. hdu 4605 题意: 有一颗树,根节点为1,每一个节点要么有两个子节点,要么没有,每个节点都有一个权值wi .然后,有一个球,附带值x . 球 ...
- HDU 5603 the soldier of love 离线+树状数组
这是bestcorder 67 div1 的1003 当时不会做 看了赛后官方题解,然后翻译了一下就过了,而且速度很快,膜拜官方题解.. 附上官方题解: the soldier of love 我们注 ...
- HDU 3887 Counting Offspring(DFS序+树状数组)
Counting Offspring Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- HDU 5869 Different GCD Subarray Query 离线+树状数组
Different GCD Subarray Query Problem Description This is a simple problem. The teacher gives Bob a ...
- HDU 4605 Magic Ball Game (在线主席树|| 离线 线段树)
转载请注明出处,谢谢http://blog.csdn.net/ACM_cxlove?viewmode=contents by---cxlove 题意:给出一棵二叉树,每个结点孩子数目为0或者2. ...
- HDU 3887:Counting Offspring(DFS序+树状数组)
http://acm.hdu.edu.cn/showproblem.php?pid=3887 题意:给出一个有根树,问对于每一个节点它的子树中有多少个节点的值是小于它的. 思路:这题和那道苹果树是一样 ...
- HDU 5293 Tree chain problem 树形dp+dfs序+树状数组+LCA
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5293 题意: 给你一些链,每条链都有自己的价值,求不相交不重合的链能够组成的最大价值. 题解: 树形 ...
- HDU 5293 Annoying problem 树形dp dfs序 树状数组 lca
Annoying problem 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5293 Description Coco has a tree, w ...
- 【BZOJ3653】谈笑风生 离线+树状数组+DFS序
[BZOJ3653]谈笑风生 Description 设T 为一棵有根树,我们做如下的定义: ? 设a和b为T 中的两个不同节点.如果a是b的祖先,那么称“a比b不知道高明到哪里去了”. ? 设a 和 ...
随机推荐
- <<< html图片背景平铺
CSS背景图片平铺技巧 使用CSS来设置背景图片同传统的做法一样简单,但相对于传统控制方式,CSS提供了更多的可控选项,我们先来看看最基本的设置图片的方法.html代码: 代码如下: <divi ...
- Java核心思想
回忆面向对象思想 面向对象,主页君也不敢对其多说什么,毕竟这是一个看似简单,但是其实蕴含很深层次理 论的东西,并不是看书就可以理解的,其实也是要在很多实际操作中学习,积累. ...
- 一次完整的HTTP请求所经历的7个步骤
HTTP通信机制是在一次完整的HTTP通信过程中,Web浏览器与Web服务器之间将完成下列7个步骤: 1. 建立TCP连接在HTTP工作开始之前,Web浏览器首先要通过网络与Web服务器建立连接,该连 ...
- ThinkPHP中疑难笔记
不但要记住核心的东西, 还要记住 相关的 东西: 如php cli的版本是 5.6.14 bulit: sep 30, 2015 tp中, 通常说的系统就是框架; 项目就是 "应用程序&qu ...
- Mac Pro 资源管理器 Double Commander“个性化设置” 备份
操作系统自带的资源管理器,总是有些别扭的地方,在 Windows 系统下,我一般用 Total Commander(破解版)来作为替代品.现在换为 Mac 系统,自带的 Finer 也不怎么好用,连最 ...
- PHP mkdir 0777权限问题
在linux系统中,即使我们使用root帐号去手工执行php命令: mkdir('test', 0777); 结果文件的权限依然为: drwxr-xr-x 2 root root 4096 Jun 1 ...
- MySQL 常用SQL技巧和常见问题
一.巧用正则表达式 二.巧用RAND() 提取随机行 利用rand() 的随机数功能,结合 order by 子句完成随机抽取某些行的功能. 三.利用 group by 的 with rollup 子 ...
- BZOJ2435——[Noi2011]道路修建
1.题意:给个树,边的权值=两边的点数差*此边的长度,求所有边的权值和 2.分析:真不想说啥了...dfs即可 #include <cmath> #include <cstdio&g ...
- javascript基础03
javascript基础03 1. 算术运算符 后增量/后减量运算符 ++ ,-- 比较运算符 ( >, <, >=, <=, ==, !=,===,!== ) 逻辑运算符( ...
- 学习 opencv---(1) opencv3.1.0 组件结构浅析
本系列是根据 浅墨大神 的opencv系列而写的,,应该大部分内容会一样..如有侵权还请告知........... 开发环境:win7 + VS2013 + opencv3.1.0 至于OpenCV组 ...