kiki君在镇妖塔中爆出了攻击力+8的护盾, 护盾是一个圆盘,圆盘上镶嵌着N颗宝石,编号为0~N-1。第i颗宝石的能量是Ai。如果Ai>0,表示这颗宝石能量过高,需要把Ai的能量传给其它宝石;如果Ai<0,表示这颗宝石的能量过低,需要从其它宝石处获取-Ai的能量。保证∑Ai =0。只有当所有宝石的能量均相同时,护盾才会被激活,并且会持续一段时间的不受伤害和攻击力提升至原来的5倍。

不过,只有M对宝石之间可以互相传递能量,其中第i对宝石之间无论传递多少能量,都要花费Ti的代价。kiki君想知道,最少需要花费多少代价才能使所有宝石的能量都相同?

输入格式

输入文件名为(shield.in)。

第一行两个整数N、M。

第二行N个整数Ai。

接下来M行每行三个整数pi,qi,Ti,表示在编号为pi和qi的宝石之间传递能量需要花费Ti的代价。数据保证每对pi、qi最多出现一次。

输出格式

输出文件名为(shield.out)。

输出一个整数表示答案。无解输出Impossible

样例
样例输入

3 3
50 -20 -30
0 1 10
1 2 20
0 2 100

样例输出

30

数据范围与提示

对于50%的数据,2<=N<=8。

对于100%的数据,2<=N<=16,0<=M<=N*(N-1)/2,0<=pi,qi<N,-1000<=Ai<=1000,0<=Ti<=1000,∑Ai=0。

状态压缩+动态规划+最小生成树
注意:枚举集合中的子集应为原始集合&(当前子集-1)

#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <cmath>
using namespace std;
const int N = 17, S = (1 << 16) - 1, Max = 1061109567;
int n, m, cost[S + 1], f[S + 1], fa[N], a[N], to[N][N], sum[S + 1];
bool flag[S + 1];
struct node {int x, y, val;
} b[400];
inline int lowbit(int x) { return x & (-x); }
bool cmp(node a, node b) { return a.val < b.val; }
inline int getfa(int x) {if (fa[x] == x)return x;return fa[x] = getfa(fa[x]);
}
inline bool kruscal(int x) {int tot = 0, ans = 0;for (int i = x; i; i -= lowbit(i)) {for (int j = 0; j < n; j++) {for (int k = j + 1; k < n; k++) {if (((i >> j) & 1) && ((i >> k) & 1)) {fa[j + 1] = j + 1;fa[k + 1] = k + 1;if (to[j + 1][k + 1]) {b[++tot].x = j + 1;b[tot].y = k + 1;b[tot].val = to[j + 1][k + 1];}}}}}sort(b + 1, b + 1 + tot, cmp);int faa;for (int i = 1; i <= tot; i++) {int x = getfa(b[i].x), y = getfa(b[i].y);if (x == y)continue;ans += b[i].val;fa[x] = y;faa = y;}bool pd = true;for (int i = 0; i < n; i++) {if (((x >> i) & 1) && getfa(i + 1) != faa)pd = false;}if (pd)cost[x] = ans;return pd;
}
inline int get(int x) {int ans = 0;for (int i = 0; i < n; i++)if (((x >> i) & 1))ans += a[i + 1];return ans;
}
int main() {cin >> n >> m;memset(f, 0x3f3f3f, sizeof(f));memset(flag, true, sizeof(flag));for (int i = 1; i <= n; i++) {cin >> a[i];}for (int i = 1; i <= m; i++) {int x, y, z;cin >> x >> y >> z;x += 1, y += 1;to[x][y] = z;to[y][x] = z;}for (int i = 1; i <= (1 << n) - 1; i++) {sum[i] = get(i);if (sum[i] != 0)flag[i] = false;if (!kruscal(i))flag[i] = false;if (flag[i])f[i] = cost[i];}for (int i = 1; i <= (1 << n) - 1; i++) {if (!flag[i])continue;for (int j = (1 << n) - 1 - i; j; j = ((1 << n) - 1 - i) & (j - 1)) {if (flag[i] && flag[j])f[i | j] = min(f[i | j], f[i] + cost[j]);}}if (f[(1 << n) - 1] == Max)cout << "Impossible" << endl;elsecout << f[(1 << n) - 1] << endl;return 0;
}

#2991. kiki君的护盾 (shield)相关推荐

  1. Unity Shader 之 简单 护盾Shield 效果的实现

    Unity Shader 之 简单 护盾Shield 效果的实现 目录 Unity Shader 之 简单 护盾Shield 效果的实现 一.简单介绍 二.实现原理

  2. Unity shader 护盾shield的简单实现

    扰动 直接对uv进行变换就可以了,记得首先把六边形格子地图的Tilling调高点 先预先调成合适大小的六边形,然后repeat铺满整个护盾 1 2 3 4 5 6 // Tiles and offse ...

  3. 【ShaderLab实例笔记】Overwatch Shield - 守望先锋护盾特效制作笔记

    教程链接:Overwatch Shield 项目链接:OverwatchShieldTemplate Pipeline & Shader:Built-in,Unlit 本文是对 Overwat ...

  4. 云中和花木_王者荣耀:体验服4位英雄加强,狂铁不再“漏电”,云中君又行了...

    王者荣耀S21赛季已经进行了快两个月的时间了,这个赛季的平衡性相当不错,基本上各个位置可玩性都不低,大多数英雄也都有出场的空间.不过还是存在一些需要打捞的英雄,曾经都辉煌过,但是如今都不太行了.在最新 ...

  5. 安全港到隐私护盾!美欧个人数据跨境流动20年政策变迁

    20年间,素来强调隐私和个人信息保护的欧盟,一直推动高标准的个人数据保护制度,甚至延伸到个人数据跨境流动.美欧之间的个人数据跨境转移政策几经变化,已经从"安全港"时代过渡到了目前的 ...

  6. Unity Shader 实现透明护盾效果

    这是大致的效果图,图片压得有点糊.我参考了本篇博客 Unity shader护盾特效. 这是原博客展示的图片: 本例采用了特殊的模型与贴图,原博客里有视频链接的教程,从模型到贴图. 以下是代码 // ...

  7. Unity shader护盾特效

    身为小白的我看到某大神用 amplify shader editor 插件做了护盾特效,很酷. 蓝色是大神做的,红色那个是我的(感觉和大神的低了几个档次,哈哈) 大神的视频链接: https://ww ...

  8. 简单力场护盾效果ASE实现笔记

    提要:基于Emission,使用多个模块分别实现细分效果并最终组装成完整护盾效果:使用Rigidbody进行碰撞检测,通过脚本将位置传进Shader,播放由参数控制的冲击效果. https://vdn ...

  9. UnityShader 简单护盾效果

    Shader "Unlit/Shield" {Properties{_Color("Color", Color) = (1,1,1,1)//圈内的颜色_RimC ...

最新文章

  1. UIView Animation
  2. nGrinder性能测试框架安装步骤
  3. Android Studio 使用Lambda
  4. cnblogs第一篇
  5. CCF 2017年题目题解 - Python
  6. Hadoop Streaming
  7. 用Python递归做个多层次的文件执行
  8. 你当初是如何走上编程之路的?
  9. try...catch...finally java
  10. mysql求和语句大全_sql查询语句大全
  11. idea新增文件自动添加到版本控制
  12. 大工20春《计算机应用基础》在线测试,大工20春《计算机应用基础》在线测试1答案...
  13. java泛型范围_Java泛型范围
  14. VMware Server 2.0下载和序列号正版
  15. 世界第一个聊天机器人源代码_这是世界上第一个“活着”的机器人
  16. 如何把鼠标宏用c语言写出来,鼠标宏怎么设置,手把手教你鼠标如何设置宏
  17. pyserial库是python语言用于,python的pyserial模块
  18. python实现简单的词形统计
  19. Flex 弹性布局(上)
  20. 律师要用到什么计算机技巧,【执业技巧】律师如何优雅地使用苹果电脑?这7款工具很有用...

热门文章

  1. r5 7600x和r7 7700x差距
  2. 计算机应用专业职业价值观,计算机应用技术专业大学生职业生涯规划书.doc
  3. 微生物群也有记忆 | 微生物群能被“训练”
  4. 你需要的iPhoneX适配
  5. 仿支付宝头像外加一个边框的工具类
  6. Python常见面试题汇总(根据面试总结)
  7. pycharm中的红色小闪电
  8. 还在搞三层架构?了解下 DDD 分层架构的三种模式吧
  9. SpringBoot框架的基本结构
  10. python编写程序判断今天是今年的第几天_python怎么判断当前日期是今年的第几天...