题解就看这位仁兄的吧…不过代码还是别看他的了…

同样的方法…我200ms,他2000ms.

常数的幽怨…

CODE

#include <bits/stdc++.h>
using namespace std;
const int MAXN = 505;
const double eps = 1e-8;
struct Point {
double x, y;
Point(){}
Point(double x, double y):x(x), y(y){}
inline Point operator -(const Point &o)const { return Point(x-o.x, y-o.y); }
inline double operator *(const Point &o)const { return x*o.y - y*o.x; }
}a[MAXN], b[MAXN];
struct Line {
Point p, v;
Line(){}
Line(const Point &p, const Point &v):p(p), v(v){}
};
inline bool On_Right(const Line &l, const Point &p) {
return (p - l.p) * l.v > eps;
}
inline int dcmp(const double &x) {
return x < -eps ? -1 : x < eps ? 0 : 1;
}
int m, n, f[MAXN][MAXN];
int main () {
scanf("%d%d", &m, &n); double o;
for(int i = 1; i <= m; ++i) scanf("%lf%lf%lf", &a[i].x, &a[i].y, &o);
for(int i = 1; i <= n; ++i) scanf("%lf%lf%lf", &b[i].x, &b[i].y, &o);
for(int i = 1; i <= m; ++i) {
for(int j = 1; j <= m; ++j)
f[i][j] = m+1;
bool flg = 1;
for(int j = 1; j <= n && flg; ++j)
if(dcmp(b[j].x-a[i].x) || dcmp(b[j].y-a[i].y)) flg = 0;
if(flg) return puts("1"), 0;
}
for(int i = 1; i <= m; ++i)
for(int j = 1; j <= m; ++j)
if(i != j && !(a[i].x == a[j].x && a[i].y == a[j].y)) { //i->j
Line tmp = Line(a[i], a[j] - a[i]);
bool flg = 1;
for(int k = 1; k <= n && flg; ++k)
if(On_Right(tmp, b[k])) flg = 0;
if(flg) {
for(int k = 1; k <= n && flg; ++k)
if
(
(!dcmp((b[k] - tmp.p) * tmp.v))
&&
((b[k].x < a[i].x && b[k].x < a[j].x)
|| (b[k].x > a[i].x && b[k].x > a[j].x)
|| (b[k].y < a[i].y && b[k].y < a[j].y)
|| (b[k].y > a[i].y && b[k].y > a[j].y)
)
) flg = 0;
if(flg) f[i][j] = 1;
}
}
for(int k = 1; k <= m; ++k)
for(int i = 1; i <= m; ++i) if(f[i][k] <= m)
for(int j = 1; j <= m; ++j) if(f[k][j]+f[i][k] <= m)
f[i][j] = min(f[i][j], f[i][k] + f[k][j]);
int ans = m+1;
for(int i = 1; i <= m; ans = min(ans, f[i][i]), ++i);
printf("%d\n", ans > m ? -1 : ans);
}

BZOJ 1027: [JSOI2007]合金 (计算几何+Floyd求最小环)的更多相关文章

  1. BZOJ 1027 JSOI2007 合金 计算几何+Floyd

    题目大意:给定一些合金,选择最少的合金,使这些合金能够按比例合成要求的合金 首先这题的想法特别奇异 看这题干怎么会想到计算几何 并且计算几何又怎么会跟Floyd挂边 好强大 首先因为a+b+c=1 所 ...

  2. 【BZOJ 1027】 (凸包+floyd求最小环)

    [题意] 某公司加工一种由铁.铝.锡组成的合金.他们的工作很简单.首先进口一些铁铝锡合金原材料,不同种类的原材料中铁铝锡的比重不同.然后,将每种原材料取出一定量,经过融解.混合,得到新的合金.新的合金 ...

  3. BZOJ 1027 [JSOI2007]合金 ——计算几何

    我们可以把每一种金属拆成一个二维向量,显然第三维可以计算出来,是无关的. 我们只需要考虑前两维的情况,显然可以构成点集所形成的凸包内. 然后我们枚举两两的情况,然后可以发现如果所有的点都在一侧是可以选 ...

  4. bzoj 1027 [JSOI2007]合金(计算几何+floyd最小环)

    1027: [JSOI2007]合金 Time Limit: 4 Sec  Memory Limit: 162 MBSubmit: 2970  Solved: 787[Submit][Status][ ...

  5. BZOJ_1027_[JSOI2007]_合金_(计算几何+Floyd求最小环)

    描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1027 共三种金属,\(m\)种材料,给出每种材料中三种金属的占比. 给出\(n\)种合金的三种 ...

  6. bzoj 1027: [JSOI2007]合金【凸包+Floyd】

    参考:https://www.cnblogs.com/zhuohan123/p/3237246.html 因为一c可以由1-a-b得出,所以删掉c,把a,b抽象成二维平面上的点.首先考虑一个客户需求能 ...

  7. BZOJ 1027 [JSOI2007]合金

    1027: [JSOI2007]合金 Time Limit: 4 Sec  Memory Limit: 162 MBSubmit: 2605  Solved: 692[Submit][Status][ ...

  8. [bzoj 1027][JSOI2007]合金(解析几何+最小环)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1027 分析: 首先因为一个合金的和为1,所以考虑2个材料合金能否合成一个需求合金的时候 ...

  9. 1027: [JSOI2007]合金 - BZOJ

    Description 某公司加工一种由铁.铝.锡组成的合金.他们的工作很简单.首先进口一些铁铝锡合金原材料,不同种类的原材料中铁铝锡的比重不同.然后,将每种原材料取出一定量,经过融解.混合,得到新的 ...

随机推荐

  1. [AT2062] ~K Perm Counting

    AT2602 , Luogu 求对于 \(n\) 个数的排列 , 有多少种方案满足对于所有的 \(i\) , \(|P_i - i| != K\) , 答案对 \(924844033\) 取模 . \ ...

  2. PTA(Basic Level)1020.月饼

    月饼是中国人在中秋佳节时吃的一种传统食品,不同地区有许多不同风味的月饼.现给定所有种类月饼的库存量.总售价.以及市场的最大需求量,请你计算可以获得的最大收益是多少. 注意:销售时允许取出一部分库存.样 ...

  3. 关于keepalived执行后日志狂刷IPVS: Can't initialize ipvs: Protocol not available的问题

    安装了keepalived+lvs,达到了高可用的负载均衡,但是今天再启用的时候发现keepalived不正常,通过 /var/log/messages 查看系统日志发现狂刷 IPVS: Can't ...

  4. Linux Crontab格式说明

    Crontab基本格式: * * * * * command 分 时 日 月 周 命令 第1列表示分钟1-59 每分钟用 */1表示 第2列表示小时1-23(0表示0点) 第3列表示日期1-31 第4 ...

  5. Linux系列之压缩与解压

    1.压缩技术 1.常用命令实例 1.zip格式的压缩与解压缩 zip是压缩指令,unzip是解压指令.zip指令既可以压缩文件,也可以压缩目录.压缩会自动保留源文件,解压会自动保留压缩文件. zip  ...

  6. golang数据类型

    整数类型   Golang各整数类型分:有符号和无符号,int uint 的大小和系统有关. Golang查看一个变量的数据类型: package main import "fmt" ...

  7. 编写程序模拟strlwr()和strupr()函数功能

    strlwr(字符串)strlwr()的作用是将字符串中大写字母转换成小写字母 strupr(字符串)strupr()的作用是将字符串中小写字母转换成大写字母 /* strlwr(字符串) strlw ...

  8. Java基础之IO和NIO补完

    Java Stream,File,IO 关于NIO和IO的比较,参考:Java NIO系列教程(十二) Java NIO与IO java包之java.io 参考材料:菜鸟教材 NIO 由于下面的系列教 ...

  9. Task资料

    5天玩转C#并行和多线程编程:http://www.cnblogs.com/yunfeifei/p/3993401.html

  10. ES6中Map与其他数据结构的互相转换

    最近在学习ES6的基础知识,整理了一下Map与其他数据结构相互转换的写法. Map转为数组的方法 let myMap = new Map([[true, 7], [{foo: 3}, ['abc']] ...