题意

给定\(n\)个炸弹,每个炸弹的坐标与代价与影响范围给定,炸弹会引爆影响范围内其他所有炸弹。求引爆所有炸弹的最小代价。

分析

先做\(n^2\)的循环,然后建图,对\(i\)能引爆\(j\)建边\((i,j)\)。然后对这个图求强连通分量并缩点,构成新的有向无环的森林。定义每个强连通分量的cost为其中包含的点的最小cost,然后把新森林中所有入度为0的点的cost加起来求和即可(由于无环,所以从任何入度不为0的点往回走,必然终止于一个入度为0的点)。

代码

#include <iostream>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <algorithm>
#include <vector>
#include <set>
#include <map>
#include <queue>
#include <stack>
#define MP make_pair
#define PB push_back
#define fi first
#define se second
#define ZERO(x) memset((x), 0, sizeof(x))
#define ALL(x) (x).begin(),(x).end()
#define rep(i, a, b) for (int i = (a); i <= (b); ++i)
#define per(i, a, b) for (int i = (a); i >= (b); --i)
#define QUICKIO \
ios::sync_with_stdio(false); \
cin.tie(0); \
cout.tie(0);
#define MS(x,y) memset(x,y,sizeof(x))
#define int ll
using namespace std;
typedef long long ll; const int MAXN=1005;
vector<int> G[MAXN];
bool mat[MAXN][MAXN];
int n;
int pre[MAXN], lowlink[MAXN], sccno[MAXN], dfs_clock, scc_cnt;
stack<int> stk; void dfs(int u)
{
pre[u]=lowlink[u] = ++dfs_clock;
stk.push(u);
rep(i,0,n-1)
{
if(!mat[u][i]) continue;
int v=i;
if(!pre[v])
{
dfs(v);
lowlink[u]=min(lowlink[u],lowlink[v]);
}
else if(!sccno[v])
{
lowlink[u]=min(lowlink[u],pre[v]);
}
}
if(lowlink[u]==pre[u])
{
scc_cnt++;
for(;;)
{
int x=stk.top(); stk.pop();
sccno[x]=scc_cnt;
if(x==u) break;
}
}
} void find_scc()
{
dfs_clock=scc_cnt=0;
ZERO(sccno);
ZERO(pre);
rep(i,0,n-1)
if(!pre[i]) dfs(i);
} bool nmat[MAXN][MAXN]; vector<pair<int,int> > edges;
vector<int> nG[MAXN];
int ncnt=0; void add_edges(int u,int v)
{
edges.PB(MP(u,v));
nG[u].PB(edges.size()-1);
} pair<int,int> pnt[MAXN];
int pntc[MAXN], pntr[MAXN]; inline double dist(int x,int y)
{
return sqrt((pnt[x].fi-pnt[y].fi)*(pnt[x].fi-pnt[y].fi)+
(pnt[x].se-pnt[y].se)*(pnt[x].se-pnt[y].se));
}
int cost[MAXN];
signed main()
{
int T; scanf("%lld", &T);
rep(kase,1,T)
{
ZERO(nmat);
ZERO(mat);
scanf("%lld", &n);
rep(i,1,n)
{
int x,y;
scanf("%lld%lld%lld%lld", &x,&y, &pntr[i], &pntc[i]);
pnt[i]=MP(x,y);
}
rep(i,1,n)
{
rep(j,1,n)
{
if(i==j) continue;
double d=pntr[i]-dist(i,j);
if(fabs(d)<1e-6 || d>1e-6)
{
mat[i-1][j-1]=true;
}
}
}
/*
rep(i,0,n-1)
{
rep(j,0,n-1)
cout<<mat[i][j]<<" ";
cout<<endl;
}
*/
find_scc();
memset(cost,0x3f,sizeof(cost));
rep(i,1,n)
{
cost[sccno[i-1]]=min(cost[sccno[i-1]],pntc[i]);
}
rep(i,0,n-1)
{
rep(j,0,n-1)
{
if(i==j) continue;
nmat[sccno[i]][sccno[j]]|=
mat[i][j];
}
}
/*
rep(i,1,scc_cnt)
{
rep(j,1,scc_cnt)
cout<<nmat[i][j]<<" ";
cout<<endl;
}
*/
ll ans=0;
/*
rep(i,0,n-1) cout<<sccno[i]<<" ";
cout<<endl;
rep(i,0,n-1) cout<<cost[i]<<" ";
cout<<endl;
*/ rep(i,1,scc_cnt)
{
int ok=0;
rep(j,1,scc_cnt)
{
if(i==j) continue;
if(nmat[j][i])
{
ok++;
break;
}
}
if(!ok)
{
//cout<<i<<" "<<cost[i]<<endl;
ans+=cost[i];
}
}
printf("Case #%lld: %lld\n", kase, ans);
}
return 0;
}

札记

这题是在一场训练赛中打的。当时的我们激情卡题两个半小时23333然后我觉得不行了只能换题,不懂图论的队友说了这题可以写,他觉得是带权并查集23333我想了一下,这一看就是缩点啊。然后缩点之后没什么好办法,不过也没浪费时间——他们还在卡题23333过了又是半个小时,他们终于出了另外一题(卡的那个签到题还是没出!!!),这个时候还剩下一个半小时了,我想到可以求和入度为0的点即可。然后又过去半个小时(出签到题啊啊啊啊啊)没出(- -|||),只好我上写这题,然后半个小时写完,5分钟调试,交上去WA,看了下代码,改了个long long,过了。后来那个签到题成功出了(太真实了),我们翻盘大成功,哇咔咔~

「国庆训练」Bomb(HDU-5934)的更多相关文章

  1. 「国庆训练」ArcSoft's Office Rearrangement(HDU-5933)

    题目与分析 题解见https://blog.csdn.net/cmershen/article/details/53200922. 训练赛场上我们写出来了--在4小时50分钟的时候...激情补题啊.. ...

  2. 「国庆训练」Kingdom of Obsession(HDU-5943)

    题意 给定\(s,n\),把\(s+1,s+2,...,s+n\)这\(n\)个数填到\(1,2,...,n\)里,要求\(x\)只能填到\(x\)的因子的位置(即题目中\(x\%y=0\)那么x才能 ...

  3. 「国庆训练&知识学习」图的最大独立集与拓展(Land of Farms,HDU-5556)

    题意 一个\(N*M\)的矩阵,其中"."代表空地,"0-9"代表古代建筑,我们如果选择了一个编号的古代建筑想要建立,那么对应就要将全部该编号的建筑建立起来,如 ...

  4. 「日常训练」 神、上帝以及老天爷 (HDU 2048)

    题意 数论中的错排问题.记错排为Dn" role="presentation">DnDn,求Dnn!" role="presentation&q ...

  5. 「日常训练」 不容易系列之(3)—— LELE的RPG难题 (HDU 2045)

    题目简述 有排成一行的n" role="presentation">nn个方格,用红(Red).粉(Pink).绿(Green)三色涂每个格子,每格涂一色,要求任何 ...

  6. 「日常训练」 Fire!(UVA-11624)

    与其说是训练不如说是重温.重新写了Java版本的代码. import java.util.*; import java.math.*; import java.io.BufferedInputStre ...

  7. 「日常训练」ZgukistringZ(Codeforces Round #307 Div. 2 B)

    题意与分析(CodeForces 551B) 这他妈哪里是日常训练,这是日常弟中弟. 题意是这样的,给出一个字符串A,再给出两个字符串B,C,求A中任意量字符交换后(不限制次数)能够得到的使B,C作为 ...

  8. 「日常训练」COMMON 约数研究(HYSBZ-1968)

    题意与分析 感谢https://www.cnblogs.com/Leohh/p/7512960.html的题解.这题话说原来不在我的训练范围,正好有个同学问我,我就拿来做做.数学果然不是我擅长的啊,这 ...

  9. 「日常训练」Mike and Feet(Codeforces Round #305 Div. 2 D)

    题意 (Codeforces 548D) 对一个有$n$个数的数列,我们要求其连续$x(1\le x\le n)$(对于每个$x$,这样的连续group有若干个)的最小数的最大值. 分析 这是一道用了 ...

随机推荐

  1. 关于<meta>的各种用处以及移动端的常见问题

    1.优先使用最新版本的IE和Chrome <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1& ...

  2. 全新释放 | RealSight APM, 让客户的极致数字体验成为可能

    根据专业评测机构 downdetector.com 统计,2018年,Facebook 系统全年宕机 200 次,Youtube 宕机  140 次,Google 宕机 100 次.每次宕机损失至少 ...

  3. csv文件已经python内置csv模块

    csv(Comma Separated Value,即逗号分隔值),文件以纯文本形式存储表格数据(数字和文本).可以用excel打开,并自动将每个逗号隔开的数据作为一列在excel中显示. pytho ...

  4. 二十四、详述 IntelliJ IDEA 中自动生成 serialVersionUID 的方法

    当我们用 IntelliJ IDEA 编写类并实现 Serializable(序列化)接口的时候,可能会遇到这样一个问题,那就是: 无法自动生成serialVersionUID. 而serialVer ...

  5. JAVA格式化解析日期

  6. window下使用Composer安装yii2

    1.在 Windows 中,先下载并运行 Composer-Setup.exe,安装过程需选择php的运行目录,安装完后在windows的cmd下运行composer看看是否安装成功 2.安装完Com ...

  7. Centos6_32位系统512M内存_如何安装gogs_Mysql_配置开机自启动

    因为有很多人的Linux版本比较低,内存配置也较低,X86 ,32位系统的:所以这里推荐采用二进制安装gogs,并且使用Mysql:这个是傻瓜式的安装方案,适合绝大多数人(提及了centos7的安装思 ...

  8. qq空间认证教程:借助企鹅媒体平台认证QQ公众空间

    年轻人,最近你是否眼看众多新开的QQ空间认证成功,自己却一筹莫展,而心情极度狂躁焦虑,别急,以下是详细教程,不能保证100%,但老夫已认证成功几个号. 不废话,直接上流程: 方法大致有2种: 1. 通 ...

  9. yii学习笔记(3),自定义全局工具函数

    在平时开发是经常需要打印数据来调试 常见的打印方式有print_r和var_dump,但是这样打印出来格式很乱不好浏览 在打印函数前后加上<pre></pre>就可以将内容原样 ...

  10. python3 练习题100例 (六)

    题目六:斐波那契数列(Fibonacci sequence),又称黄金分割数列,指的是这样一个数列:0.1.1.2.3.5.8.13.21.34.……. #!/usr/bin/env python3 ...