题目链接:##

传送门

题目大意:##

Bob非常享受玩电脑游戏的过程,尤其是策略游戏,但是在有些时候,他因为不能在第一时间找到最佳的策略而十分伤心。 现在,他遇到了一个问题。他必须保卫一个中世纪的城市,有很多道路将整个城市连起来,整体上看上去像一棵树。Bob需要放置尽可能少的士兵,保卫树上所有的边。士兵只能放在节点上,但是却可以保卫所有与这个节点相邻的边。

题目分析:##

由于树本身具有二分图的性质,所以这里我把树手动染色转成二分图,然后跑最小点覆盖

(当然也可以树形dp)

代码:##

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#define N (1500 + 5)
using namespace std;
inline int read(){
int cnt = 0, f = 1; char c;
c = getchar();
while (!isdigit(c)) {
if(c == '-') f = -f;
c = getchar();
}
while (isdigit(c)) {
cnt = cnt * 10 + c - '0';
c = getchar();
}
return cnt * f;
}
int n, nxt[2*N], to[2*N], first[2*N], tot, x, t, y, Float[N], cnt, black, white, ans, match[N];
bool vis[N];
struct node{
int x;int y;
}edge[N];
void add(int x, int y) {
nxt[++tot] = first[x];
first[x] = tot;
to[tot] = y;
}
void Dfs(int u){
for (register int i = first[u]; i; i = nxt[i]) {
int v = to[i];
if(!Float[v]) {
Float[v] = Float[u] + 1;
Dfs(v);
}
}
}
void build_map() {
memset (first, 0, sizeof(first));
memset (nxt, 0, sizeof(nxt));
memset (to, 0, sizeof(to));
tot = 0;
for (register int i = 1; i <= cnt; i++) {
int X = edge[i].x; int Y = edge[i].y;
if (Float[X] % 2 == 1) {
add(X, Y);
if (!vis[X]) {
vis[X] = true;
black++;
}
if (!vis[Y]) {
vis[Y] = true;
white++;
}
} else {
add(Y, X);
if (!vis[X]) {
vis[X] = true;
white++;
}
if (!vis[Y]) {
vis[Y] = true;
black++;
}
}
}
}
int find(int u) {
// cout<<u<<"##"<<endl;
for (register int i = first[u]; i; i = nxt[i]) {
int v = to[i];
// cout<<vis[v]<<" "<<v<<endl;
if (vis[v]) {
continue;
} else {
vis[v] = true;
if (match[v] == -1||find(match[v])) {
match[v] = u;
return 1;
}
}
}
return 0;
} int hungary() {
for (register int i = 1; i <= n; i++) match[i] = -1;
for (register int i = 1; i <= n; i++) {
for (register int j = 1; j <= n; j++) vis[j] = 0;
ans += find(i);
}
return ans;
} int main(){
while(scanf("%d", &n) != EOF) {
memset(first, 0, sizeof(first));
memset(nxt, 0, sizeof(nxt));
memset(to, 0, sizeof(to));
memset(Float, 0, sizeof(Float));
memset(vis, 0, sizeof(vis));
tot=0; cnt=0; ans=0;
for (register int i = 1; i <= n; i++) {
x = read();
t = read();
for (register int j = 1; j <= t; j++) {
y = read();
edge[++cnt].x = x+1;
edge[cnt].y = y+1;
add(x+1,y+1);
add(y+1,x+1);
}
}
Float[1] = 1;
Dfs(1);
build_map();
// cout<<black<<" "<<white<<endl;
// for(register int i = 1; i <= n; i++) cout<<Float[i];
int res = hungary();
printf("%d\n", res);
} return 0;
}

[POJ1463] Strategic game的更多相关文章

  1. poj1463 Strategic game (树状dp)

    Strategic game Time Limit: 2000MS   Memory Limit: 10000K Total Submissions: 5498   Accepted: 2484 De ...

  2. poj1463 Strategic game【树形DP】

    Strategic game Time Limit: 2000MS   Memory Limit: 10000K Total Submissions: 9582   Accepted: 4516 De ...

  3. POJ1463 Strategic game (最小点覆盖 or 树dp)

    题目链接:http://poj.org/problem?id=1463 给你一棵树形图,问最少多少个点覆盖所有的边. 可以用树形dp做,任选一点,自底向上回溯更新. dp[i][0] 表示不选i点 覆 ...

  4. poj1463 Strategic game[树形DP]

    求一棵树每条边都被选上的点覆盖掉的最少选点数. 一条边被覆盖掉,必须他父亲和儿子中选一个..这不就是比NOIP2018D2T3还裸的暴力么.水掉. lyd给的练习题都什么**玩意儿.. code不挂了 ...

  5. 树形DP入门题目推荐以及解析

    关于树形DP几道入门题目 今天恶补树形DP,感觉海星. 其实挺简单的. 介绍几道例题,我会的. 1.洛谷P1352 没有上司的舞会 我的一篇题解 我们可以考虑每一个节点都是有两种情况. 一个是被邀请: ...

  6. POJ1463:Strategic game(树形DP)

    Description Bob enjoys playing computer games, especially strategic games, but sometimes he cannot f ...

  7. Strategic game树形DP解法(Poj1463,Uva1292)

    已经写过本题用二分图的做法,见这儿. 本题的图是一棵树,求最小点覆盖也可以用树形DP的做法. 定义状态f[0/1][u]表示以u为根的子树,u选取/不选最少需要选取多少点来覆盖. 显然 f[0][u] ...

  8. Strategic game(无向?)二分图最小点覆盖(Poj1463,Uva1292)

    原题链接 此题求二分图的最小点覆盖,数值上等于该二分图的最大匹配.得知此结论可以将图染色,建有向图,然后跑匈牙利/网络流,如下.然而... #include<iostream> #incl ...

  9. HDU1054 Strategic Game——匈牙利算法

    Strategic Game Bob enjoys playing computer games, especially strategic games, but sometimes he canno ...

随机推荐

  1. Appium——Error while obtaining UI hierarchy XML file:com.android.ddmlib.SyncException:

    使用uiautomatorviewer查看页面元素时报这个错误,解决办法 cmd: adb root ok  解决

  2. legend2---开发日志12(vue如何进一步学习)

    legend2---开发日志12(vue如何进一步学习) 一.总结 一句话总结:还是得找教程(比如视频),自己摸索太浪费时间,也容易踩坑和抓不住重点 还是得找教程(比如视频),自己摸索太浪费时间,也容 ...

  3. LA-3942(trie树+dp)

    题意: 给出一个由多个不同单词组成的字典,和一个长字符串,把这个字符串分解成若干个单词的连接,问有多少种方法; 思路: dp[i]表示s[i,L]的方案数,d[i]=∑d[j];s[i,j-1]是一个 ...

  4. hdu-5724 Chess(组合游戏)

    题目链接: Chess Time Limit: 2000/1000 MS (Java/Others)     Memory Limit: 65536/65536 K (Java/Others) Pro ...

  5. June 25,2014---->Binder(IPC),Dalvik ,DEX/ODEX

    1.Binder(IPC) Linux进程之间要能够互相通信,从而共享资源和信息.所以,操作系统内核必须提供进程间的通信机制(IPC,Inter-Process Communication). IPC ...

  6. Android设备管理器 DevicePolicyManager

    设备管理器有个特点,你注册了之后如果不解除注册就会难以卸载带有设备管理器的应用,目前4.3版本仍未提示用户如何卸载,maybe later. 在「设定-安全」你可以看见「设备管理器」,它提供一些高级功 ...

  7. JavaWeb之动态页面技术JSP/EL/JSTL

    一.JSP技术 1.jsp脚本和注释 jsp脚本: 1)<%java代码%> ----- 内部的java代码翻译到service方法的内部 2)<%=java变量或表达式> - ...

  8. C++之虚函数与虚继承详解

    准备工作 1.VS2012使用命令行选项查看对象的内存布局 微软的Visual Studio提供给用户显示C++对象在内存中的布局的选项:/d1reportSingleClassLayout.使用方法 ...

  9. gulp --- 前端自动化构建工具

    目录 1. gulp使用步骤 1.1 安装Node.js 1.2 全局安装gulp 1.3 安装项目依赖包gulp 1.3.1 了解package.json 1.3.2 根据package.json安 ...

  10. FFmpeg常用命令 (三)流媒体

    前言 如此强大的FFmpeg,能够实现视频采集.视频格式转化.视频截图.视频添加水印.视频切片.视频录制.视频推流.更改音视频参数功能等.通过终端命令如何实现这些功能,Richy在本文做一记录,以备之 ...