标签:hdu
4 0 9 8 6 5
2题意:对于一个图,两个人轮流取点,谁取得那个点则获得那个点的价值,而一个人如果取得同一条边的两点,则同时也会获得这条边的价值,两人都按最优方案去取,最后输出价值之差思路:只要将边分半给两个点即可,如果两点同时在一个人身上,那么边的价值也会加上去,如果两点在两个人身上,那么边的价值会被减去#include <iostream> #include <stdio.h> #include <string.h> #include <stack> #include <queue> #include <map> #include <set> #include <vector> #include <math.h> #include <bitset> #include <algorithm> #include <climits> using namespace std; #define ls 2*i #define rs 2*i+1 #define UP(i,x,y) for(i=x;i<=y;i++) #define DOWN(i,x,y) for(i=x;i>=y;i--) #define MEM(a,x) memset(a,x,sizeof(a)) #define W(a) while(a) #define gcd(a,b) __gcd(a,b) #define LL long long #define N 100005 #define MOD 1000000007 #define INF 0x3f3f3f3f #define EXP 1e-8 #define rank rank1 const int mod = 10007; int n,m; double a[N]; int main() { int i,j,k,x,y; double w; while(~scanf("%d%d",&n,&m)) { for(i = 1; i<=n; i++) scanf("%lf",&a[i]); for(i = 1; i<=m; i++) { scanf("%d%d%lf",&x,&y,&w); w=w/2; a[x]+=w; a[y]+=w; } sort(a+1,a+1+n); double sum1=0,sum2=0; for(i = 1; i<=n; i++) { if(i%2==0) sum1+=a[i]; else sum2+=a[i]; } printf("%.0f\n",sum1-sum2); } return 0; }
版权声明:本文为博主原创文章,未经博主允许不得转载。
HDU4647:Another Graph Game(贪心)
标签:hdu
原文地址:http://blog.csdn.net/libin56842/article/details/46929267