题意与分析(CodeForces 580C)

给你一棵树,然后每个叶子节点会有一家餐馆;你讨厌猫(waht?怎么会有人讨厌猫),就不会走有连续超过m个节点有猫的路。然后问你最多去几家饭店。

这题我写的挫的要死,实际上只需要一次dfs就可以解决了,我愣是用了一次bfs+一次dfs来写——dfs是为了判断是否是叶子节点的。。。。但是bfs干的活完全可以让dfs在找叶子节点的时候顺带解决了,所以就很坑。

一个比较好的写法见https://www.cnblogs.com/qscqesze/p/4831507.html。

代码

#include <bits/stdc++.h>
#define MP make_pair
#define PB emplace_back
#define fi first
#define se second
#define ZERO(x) memset((x), 0, sizeof(x))
#define ALL(x) (x).begin(),(x).end()
#define rep(i, a, b) for (repType i = (a); i <= (b); ++i)
#define per(i, a, b) for (repType i = (a); i >= (b); --i)
#define QUICKIO \
ios::sync_with_stdio(false); \
cin.tie(0); \
cout.tie(0);
using namespace std;
using ll=long long;
using repType=ll;
const int MAXN=100000+5; bool red[MAXN];
bool ok[MAXN];
bool vis[MAXN];
vector<int> G[MAXN],nG[MAXN];
int n; int dfs(int x)
{
if(nG[x].size()==0)
{
//cout<<x<<endl;
return ok[x];
}
else
{
int ans=0;
rep(i,0,int(nG[x].size())-1)
ans+=dfs(nG[x][i]);
return ans;
}
} int bfs(int m)
{
ZERO(ok);
queue<pair<int,int> > q;
q.push(MP(1,0)); vis[1]=true;
while(!q.empty())
{
auto now=q.front(); q.pop();
//cout<<now.fi<<" "<<now.se<<" "<<red[now.fi]<<endl;
if(now.se+red[now.fi]>m) continue;
else ok[now.fi]=true;
rep(i,0,int(G[now.fi].size())-1)
{
int v=G[now.fi][i];
if(!vis[v])
{
vis[v]=true;
nG[now.fi].PB(v);
if(red[now.fi])
q.push(MP(v,now.se+1));
else q.push(MP(v,0));
}
}
}
return dfs(1);
} int main()
{
int m;
cin>>n>>m;
rep(i,1,n) cin>>red[i];
rep(i,1,n)
{
int x,y; cin>>x>>y;
G[x].PB(y);
G[y].PB(x);
}
ZERO(vis);
cout<<bfs(m)<<endl; return 0;
}

最新文章

  1. Swift基础--可选绑定和守护绑定
  2. 使用LTT升级HP磁带机的固件程序
  3. TrineaAndroidCommon API Guide
  4. MVC神韵---你想在哪解脱!(十一)
  5. 数据结构练习 00-自测5. Shuffling Machine (20)
  6. Linux系统重启network服务失败
  7. Go如何发送广播包
  8. UVA10537 Toll! Revisited
  9. Laravel Eloquent get获取空的数据问题
  10. linux系统参数调优
  11. bzoj [Noi2002]Savage 扩展欧几里得
  12. 【转载】.NET压缩/解压文件/夹组件
  13. java 程序运行过程 简介
  14. MySQL(二)数据的检索和过滤
  15. sql文件或连接数据库反向生成pdm文件
  16. SQL之层次查询
  17. 【Android内存泄漏检测】LeakCanary使用总结
  18. python 使用exchange发送邮件(三)
  19. [Node.js]29. Level 6: Socket.io: Setting up Socket.io server-side &amp; Client socket.io setup
  20. 【转】VS2008快速将代码中字符串改为_T(“”)风格的方法

热门文章

  1. CF13C Sequence
  2. 怎么解决深入学习PHP的瓶颈?
  3. 理解HTML DOM
  4. Hello, GitHub!
  5. CSS3-阴影参数基础
  6. 课时53.video标签(掌握)
  7. asp.net mvc5 step by step(一)——CURD增删查改Demo
  8. iOS安装CocoaPods详细过程
  9. #leetcode刷题之路8-字符串转换整数 (atoi)
  10. angularjs中控制器之间的通信----$on、$emit和$broadcast解析