HDU 3339 In Action

来源:互联网 发布:雅思还是托福 知乎 编辑:程序博客网 时间:2024/05/20 09:23


http://acm.hdu.edu.cn/showproblem.php?pid=3339

大致题意是说:

有n个电站,每个电站都有一定的电量,电站之间有一定距离,我们要从0点出发去占领一些电站,使得占领的电站电量之和超过总电量的一半,求达到条件所要走的最短距离。如果可能的话,输出距离,否则输出不可能。

思路:

我们从0点开始派出一些tank去占领一些电站,坦克到每个电站都有一定距离,而占领每个电站之后可以得到一定电量,距离就相当于体积v,电量就相当于价值w,这不是就01背包吗?01背包通常的问法是给定体积,求获得最大的价值,这里的问法是给定价值,求恰好得到或多于该价值时的最小体积。我们只要从前向后搜索,找到第一个大于该价值的体积即可。

#include <stdio.h>#include <string.h>#include <iostream>#include <algorithm>using namespace std;const int INF = 0x7fffff;const int N = 110;int G[N][N],power[N],dis[N],vis[N],dp[N*N];int n,m;void dijkstra(int scr){    for(int i=1; i<=n; i++){        dis[i] = G[scr][i];        vis[i] = 0;    }    vis[scr] = 1;    for(int i=1; i<n; i++){        int tmp = INF, k = scr;        for(int j=1; j<=n; j++){            if(vis[j])  continue;            if(dis[j] < tmp){                tmp = dis[j];                k = j;            }        }        if(tmp == INF)  return;        vis[k] = 1;        for(int j=1; j<=n; j++){            if(vis[j])  continue;            dis[j] = min(dis[j], dis[k] + G[k][j]);        }    }}int main(){//    freopen("in.txt", "r", stdin);    int cas;    scanf("%d",&cas);    while(cas--){        scanf("%d%d",&n,&m);        for(int i=0; i<=n; i++)            for(int j=0; j<=n; j++){                if(i == j)  G[i][j] = 0;                else G[i][j] = INF;            }        int x,y,d;        for(int i=0; i<m; i++){            scanf("%d%d%d",&x,&y,&d);            if(d < G[x][y])///防止重边                G[x][y] = G[y][x] = d;        }        for(int i=1; i<=n; i++)            scanf("%d",&power[i]);        dijkstra(0);        int v = 0, w = 0, flag = 1;        for(int i=1; i<=n; i++){            w += power[i];            v += dis[i];            if(dis[i] == INF){                flag = 0;                break;            }        }        if(!flag){            puts("impossible");            continue;        }        for(int i=0; i<=v; i++)            dp[i] = 0;        for(int i=1; i<=n; i++){            for(int j=v; j>=dis[i]; j--){                dp[j] = max(dp[j], dp[j - dis[i]] + power[i]);            }        }        w = w/2 + 1;        for(int i=1; i<=v; i++){            if(dp[i] >= w){                printf("%d\n",i);                break;            }        }    }    return 0;}

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 花椒树树叶掉落枝干发黑怎么办 茉莉枝干变干了怎么办 冲风了头蒙怎么办 不小心把腰扭了怎么办 白衣服发霉有小黑点怎么办 佛肚竹的枝叶都枯了怎么办 山竹一天吃多了怎么办 水养竹子叶子发黄怎么办 龙竹的竹杆黄了怎么办 散尾竹叶子发黑怎么办 给姐姐打工不发工资怎么办? 水培红掌叶子发黄怎么办 盆竹的叶尖发黄怎么办 养富贵竹水里怎么生小虫怎么办 盆栽金银花叶子全部落掉怎么办 荷花竹根部烂了怎么办 水培绿萝叶子发黄怎么办 大早上的公鸡老打鸣怎么办 紫吊兰叶子变绿怎么办 芙桑花叶子发黄怎么办 长春花长得太高怎么办 四季梅叶子蔫了怎么办 吸财树叶子蔫了怎么办 民族团结手抄报间单有漂亮怎么办 鹦鹉尾巴毛掉了怎么办 羊绒衫领子打太大了怎么办 内裤洗了还有一股味道怎么办 月经下不来内裤上总有脏东西怎么办 夏天外衣薄露出内衣怎么办 金毛体味很重怎么办 直筒连衣裙太短怎么办 托班社会下雨了怎么办 托班下雨了怎么办教案 吃鸡界面有鼠标怎么办 老年机成英语了怎么办 手机成了英语了怎么办 塑料袋融化粘到衣服上怎么办 厕所被卫生纸堵了怎么办 钻石画的胶不粘了怎么办 客厅沙发选大了怎么办 连衣裙腰大了怎么办呀