zoukankan      html  css  js  c++  java
  • POJ1463

    每条边至少要有一个端点有士兵,求最少需要士兵数。
    因此,如果子树的根节点不放士兵,那么其所有的直接儿子节点必须都放上士兵。
    状态转移方程:
    sol[root][0] += sol[G[root][i]][1];
    sol[root][1] += min(sol[G[root][i]][0], sol[G[root][i]][1]);

    /**/
    #include <cstdio>
    #include <cstring>
    #include <cmath>
    #include <cctype>
    #include <iostream>
    #include <algorithm>
    #include <map>
    #include <set>
    #include <vector>
    #include <string>
    #include <stack>
    #include <queue>
    
    typedef long long LL;
    typedef unsigned long long ULL;
    using namespace std;
    
    //bool Sqrt(LL n) { return (LL)sqrt(n) * sqrt(n) == n; }
    const double PI = acos(-1.0), ESP = 1e-10;
    const LL INF = 99999999999999;
    const int inf = 999999999, N = 1500 + 24;
    int sol[N][2], fa[N], n;
    vector<int> G[N]; //用邻接表存储树
    
    void dfs(int root) 
    {
    	for(int i = 0; i < G[root].size(); i++) dfs(G[root][i]);
    	for(int i = 0; i < G[root].size(); i++) {
    		sol[root][0] += sol[G[root][i]][1];
    		sol[root][1] += min(sol[G[root][i]][0], sol[G[root][i]][1]);
    	}
    }
    
    int main()
    {
    	//freopen("in.txt", "r", stdin);
    	//freopen("out.txt", "w", stdout);
    	while(~scanf("%d", &n)) {
    		for(int i = 0; i < n; i++) {
    			G[i].clear();
    			sol[i][1] = 1; sol[i][0] = 0;
    			fa[i] = -1;
    		}
    		for(int i = 0; i < n; i++) {
    			int root, node, cnt;
    			scanf("%d:(%d)", &root, &cnt);
    			for(int i = 0; i < cnt; i++) {
    				scanf("%d", &node);
    				G[root].push_back(node);
    				fa[node] = root;
    			}
    		}
    		int root = 1;
    		while(fa[root] != -1) root = fa[root]; //这样来找根节点
    		dfs(root);
    		printf("%d
    ", min(sol[root][0], sol[root][1]));
    	}
    
    	return 0;
    }
    /*
        input:
        output:
        modeling:
        methods:
        complexity:
        summary:
    */
    

    这道题与POJ2342类似,都是在直接父子关系的节点之间。

  • 相关阅读:
    Oracle 获取本周、本月、本季、本年的第一天和最后一天(转载)
    easyui tabs页签显示在底部属性
    java mybatis XML文件中大于号小于号转义(转载)
    原生JS日历 + JS格式化时间格式
    ajax之async属性
    Easyui 行编辑
    css中实现显示和隐藏(转)
    layer弹出层 获取index
    js中关于json常用的内容、js将数字保留两位小数
    发布项目到github上web服务器来运行
  • 原文地址:https://www.cnblogs.com/000what/p/11650384.html
Copyright © 2011-2022 走看看