Perfect Service

描述
网络由N个通过N-1个通信链路连接的计算机组成,使得任何两台计算机可以通过独特的路由进行通信。如果两台计算机之间存在通信链路,则称这两台计算机是相邻的。计算机的邻居是与它相邻的一组计算机。为了快速访问和检索大量信息,我们需要选择一些作为服务器的计算机向其邻居提供资源。请注意,服务器可以为其所有邻居提供服务。如果每个客户端(非服务器)由一个服务器提供服务,则网络中的一组服务器形成完美的服务。问题是找到最少数量的服务器,形成一个完美的服务,我们称这个号码完美的服务号码。
我们假设N(≤10000)是一个正整数,这N个计算机的编号从1到N.例如,图1示出了由六个计算机组成的网络,其中黑色节点表示服务器,白色节点表示客户端。在图1(a)中,服务器3和5不形成完美的服务,因为客户端4与服务器3和5两者相邻,因此由两个服务器服务,这与服务器相违背。相反,服务器3和4形成完美的服务,如图1(b)所示。这个集合也具有最小的基数。因此,这个例子的完美服务号码等于两个。
您的任务是编写一个程序来计算完美的服务号码。

输入
输入由多个测试用例组成。每个测试用例的格式如下:第一行包含一个正整数N,表示网络中的计算机数量。下一个N-1行包含所有通信链路,每条链路包含一行。每行由两个由单个空格分开的正整数表示。最后,第(N + 1)行的0表示第一个测试用例的结束。
下一个测试用例从上一个结束符号0开始。-1表示整个输入的结束。

输出
输出包含每个测试用例的一行。每行包含正整数,即
完美的服务号码。

样例输入
6
1 3
2 3
3 4
4 5
4 6
0
2
1 2
-1

样例输出
2
1

显然,一个很裸的最小支配集

使用树形DP的做法:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#define inf 9999999
#define maxn 10005
using namespace std;
int n,head[maxn*2],dp[maxn][3],cnt;
struct Edge{
int to;int next;
}edge[2*maxn];
void add(int u,int v)
{
edge[cnt].to=v;
edge[cnt].next=head[u];
head[u]=cnt++;
}
void DP(int x,int fa)
{
dp[x][0]=1;dp[x][2]=0;
int sum=0,inc=inf;bool flag=false;
for(int i=head[x];i!=-1;i=edge[i].next)
{
int to=edge[i].to;
if(to==fa) continue;
DP(to,x);
dp[x][0]+=min(dp[to][0],min(dp[to][1],dp[to][2])); if(dp[to][0]<=dp[to][1])
{
sum+=dp[to][0];
flag=true;
}
else
{
sum+=dp[to][1];
inc=min(inc,dp[to][0]-dp[to][1]);
} if(dp[to][1]!=inf&&dp[x][2]!=inf) dp[x][2]+=dp[to][1];
else dp[x][2]=inf;
}
if(inc==inf&&!flag)
dp[x][1]=inf;
else
{
dp[x][1]=sum;
if(!flag)
dp[x][1]+=inc;
}
}
int main()
{
int a,b,t;
while(scanf("%d",&n))
{
memset(head,-1,sizeof(head));
for(int i=1;i<n;i++)
{
scanf("%d %d",&a,&b);
add(a,b);add(b,a);
}
scanf("%d",&t);
DP(1,0);
printf("%d\n",min(dp[1][0],dp[1][1]));
if(t==-1) break;
}
return 0;
}

使用贪心的做法:

`#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
#define maxn 10005
using namespace std;
int head[2*maxn],ans,n,cnt,point,book[maxn],fa[maxn];
bool vis[maxn];
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch>'9'||ch<'0') {if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9') {x=x*10+ch-'0';ch=getchar();}
return x*f;
}
struct Edge{
int to;int next;
}edge[2*maxn];
inline void add(int u,int v)
{
edge[cnt].to=v;
edge[cnt].next=head[u];
head[u]=cnt++;
}
void dfs(int index)
{
book[++point]=index;
int i,j;
for(i=head[index];i!=-1;i=edge[i].next)
{
if(!vis[edge[i].to])
{
vis[edge[i].to]=true;
fa[edge[i].to]=index;
dfs(edge[i].to);
}
}
}
inline void mds()
{
int i,j;
bool s[maxn],set[maxn];
memset(s,0,sizeof(s));
memset(set,0,sizeof(set));
for(i=n;i>=1;i--)
{
int now=book[i];
if(!s[i])
{
if(!set[fa[i]])
{
set[fa[i]]=true;
++ans;
}
s[i]=true;
s[fa[i]]=true;
s[fa[fa[i]]]=true;
}
}
}
int main()
{
int i,j,k,t;
while(1)
{
n=read();
point=0;
ans=0;
cnt=0;
memset(edge,0,sizeof(edge));
memset(book,0,sizeof(book));
memset(fa,0,sizeof(fa));
memset(vis,0,sizeof(vis));
memset(head,-1,sizeof(head));
for(i=1;i<n;i++)
{
k=read();t=read();
add(k,t);
add(t,k);
}
t=read();
vis[1]=true;
dfs(1);
mds();
printf("%d\n",ans);
if(t==-1)break; } return 0;

Perfect Service [POJ 3398]的更多相关文章

  1. POJ 3398 Perfect Service(树型动态规划,最小支配集)

    POJ 3398 Perfect Service(树型动态规划,最小支配集) Description A network is composed of N computers connected by ...

  2. Luogu 1894 [USACO4.2]完美的牛栏The Perfect Stall / POJ 1274 The Perfect Stall(二分图最大匹配)

    Luogu 1894 [USACO4.2]完美的牛栏The Perfect Stall / POJ 1274 The Perfect Stall(二分图最大匹配) Description 农夫约翰上个 ...

  3. UVA - 1218 Perfect Service(树形dp)

    题目链接:id=36043">UVA - 1218 Perfect Service 题意 有n台电脑.互相以无根树的方式连接,现要将当中一部分电脑作为server,且要求每台电脑必须连 ...

  4. UVa 1218 - Perfect Service

    /*---UVa 1218 - Perfect Service ---首先对状态进行划分: ---dp[u][0]:u是服务器,则u的子节点可以是也可以不是服务器 ---dp[u][1]:u不是服务器 ...

  5. Perfect service(树形dp)

    Perfect service(树形dp) 有n台机器形成树状结构,要求在其中一些机器上安装服务器,使得每台不是服务器的计算机恰好和一台服务器计算机相邻.求服务器的最小数量.n<=10000. ...

  6. POJ 3398 Perfect Service --最小支配集

    题目链接:http://poj.org/problem?id=3398 这题可以用两种上述讲的两种算法解:http://www.cnblogs.com/whatbeg/p/3776612.html 第 ...

  7. 【POJ】3398 Perfect Service

    1. 题目描述某树形网络由$n, n \in [1, 10^4]$台计算机组成.现从中选择一些计算机作为服务器,使得每当普通计算机恰好与一台服务器连接(并且不超过一台).求需要指定服务器的最少数量 2 ...

  8. POJ 1274 The Perfect Stall || POJ 1469 COURSES(zoj 1140)二分图匹配

    两题二分图匹配的题: 1.一个农民有n头牛和m个畜栏,对于每个畜栏,每头牛有不同喜好,有的想去,有的不想,对于给定的喜好表,你需要求出最大可以满足多少头牛的需求. 2.给你学生数和课程数,以及学生上的 ...

  9. Perfect Service

    题意: n个节点树,在一个节点放上一台服务器可以给相邻的其他各点提供服务且一个节点只能接受一台服务器,求使n个节点都被服务放的服务器的最小数量. 分析: 不算太难,状态想的差不多,但是考虑不全面状态方 ...

随机推荐

  1. 常见的爬虫分析库(3)-Python正则表达式与re模块

    在线正则表达式测试 http://tool.oschina.net/regex/ 常见匹配模式 模式 描述 \w 匹配字母数字及下划线 \W 匹配非字母数字下划线 \s 匹配任意空白字符,等价于 [\ ...

  2. Tensorflow生成唐诗和歌词(上)

    整个工程使用的是Windows版pyCharm和tensorflow. 源码地址:https://github.com/Irvinglove/tensorflow_poems/tree/master ...

  3. SQL Server常见的操作符

    常见的操作符:Sort.Hash Match(聚合).Filter.Compute Scalar等 一:Sort select Shelf from Production.ProductInvento ...

  4. jdk1.8学习、jdk1.9学习、jdk10.0学习和总结

    由于中文参考资料很少,参考链接: https://www.oschina.net/translate/109-new-features-in-jdk-10 http://chuansong.me/n/ ...

  5. Eclipse+Maven整合开发Java项目(一)➣Maven基础环境配置

    概述 Maven是一个Java语言编写的开源项目管理工具,是Apache软件基金会的顶级项目.主要用于项目构建,依赖管理,项目信息管理.有些项目需要添加响应的依赖包,Maven就是公用包集合.存在远程 ...

  6. python之https爬虫出现 SSL: CERTIFICATE_VERIFY_FAILED (同时打开fiddler就会出现)

    1.参考 Py 坑之 CERTIFICATE_VERIFY_FAILED Python 升级到 2.7.9 之后引入了一个新特性,当你urllib.urlopen一个 https 的时候,会验证一次 ...

  7. .net core 中的 DependencyInjection - IOC

    概要:因为不知道写啥,所以随便找个东西乱说几句,嗯,就这样,就是这个目的. 1.IOC是啥呢? IOC - Inversion of Control,即控制反转的意思,这里要搞明白的就是,它是一种思想 ...

  8. win7自带截屏便签 打开命令

    win7自带截屏 1.win+r 2.SnippingTool.exe    打开 便签 1.win+r 2.StikyNot.exe    打开 查本机ip 1.win+r 2.cmd 3.ipco ...

  9. NEST 中的距离单位

    Distance units Version: 5.x 英文原文地址:Distance units 当我们需要指定距离时(地理位置查询),可以使用一个双精度的数字来表示,它的默认单位是米(meters ...

  10. Codeforces 1132E (看题解)

    感觉这个题挺有意思的, 我们可以将 L = lcm(1, 2, 3, ... , 8) 看作一组. 然后用dp[ i ][ j ]表示到第 i 种物品当前的值为 j 能用L的最大数量. #includ ...