题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2395

参考博客:https://www.cnblogs.com/autsky-jadek/p/3959446.html

但复杂度不太会算;

递归边界不要取两个点相等,而是叉积>=0 。

代码如下:

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
typedef long long ll;
int const xn=,xm=1e4+;
int n,m,fa[xn],dis[xn];
ll ansx,ansy;
struct N{
int u,v,a,b; ll w;
bool operator < (const N &y) const
{return w<y.w;}
}ed[xm];
struct P{
ll x,y;
P(ll x=,ll y=):x(x),y(y) {}
};
P operator - (const P &A,const P &B){return P(A.x-B.x,A.y-B.y);}
ll cross(P A,P B){return A.x*B.y-A.y*B.x;}
int rd()
{
int ret=,f=; char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=; ch=getchar();}
while(ch>=''&&ch<='')ret=ret*+ch-'',ch=getchar();
return f?ret:-ret;
}
int find(int x){return fa[x]==x?x:fa[x]=find(fa[x]);}
void uni(int x,int y)
{
if(dis[x]==dis[y])fa[x]=y,dis[y]++;
else if(dis[x]<dis[y])fa[x]=y;
else fa[y]=x;
}
P kruskal()
{
int cnt=; P ret=P(,);
memset(dis,,sizeof dis);
for(int i=;i<=n;i++)fa[i]=i;
sort(ed+,ed+m+);
for(int i=;i<=m;i++)
{
int x=find(ed[i].u),y=find(ed[i].v);
if(x==y)continue;
ret.x+=ed[i].a; ret.y+=ed[i].b;
uni(x,y); cnt++;
if(cnt==n-)break;
}
return ret;
}
bool eql(P A,P B){return A.x==B.x&&A.y==B.y;}
void solve(P A,P B)
{
for(int i=;i<=m;i++)ed[i].w=ed[i].b*(B.x-A.x)+ed[i].a*(A.y-B.y);
P C=kruskal();
if(cross(B-A,C-A)>=)return;//>=0
//if(eql(A,C)||eql(B,C))return;
if((C.x*C.y<ansx*ansy)||(C.x*C.y==ansx*ansy&&C.x<ansx))ansx=C.x,ansy=C.y;
solve(A,C); solve(C,B);
}
int main()
{
n=rd(); m=rd();
for(int i=;i<=m;i++)
ed[i].u=rd()+,ed[i].v=rd()+,ed[i].a=rd(),ed[i].b=rd();
for(int i=;i<=m;i++)ed[i].w=ed[i].a;
P A=kruskal();
for(int i=;i<=m;i++)ed[i].w=ed[i].b;
P B=kruskal();
if((A.x*A.y<B.x*B.y)||(A.x*A.y==B.x*B.y&&A.x<B.x))ansx=A.x,ansy=A.y;
else ansx=B.x,ansy=B.y;
solve(A,B);
printf("%lld %lld\n",ansx,ansy);
return ;
}

bzoj 2395 Timeismoney —— 最小乘积生成树的更多相关文章

  1. bzoj2395[Balkan 2011]Timeismoney最小乘积生成树

    所谓最小乘积生成树,即对于一个无向连通图的每一条边均有两个权值xi,yi,在图中找一颗生成树,使得Σxi*Σyi取最小值. 直接处理问题较为棘手,但每条边的权值可以描述为一个二元组(xi,yi),这也 ...

  2. 【BZOJ2395】【Balkan 2011】Timeismoney 最小乘积生成树

    链接: #include <stdio.h> int main() { puts("转载请注明出处[辗转山河弋流歌 by 空灰冰魂]谢谢"); puts("网 ...

  3. Bzoj2395: [Balkan 2011]Timeismoney(最小乘积生成树)

    问题描述 每条边两个权值 \(x,y\),求一棵 \((\sum x) \times (\sum y)\) 最小的生成树 Sol 把每一棵生成树的权值 \(\sum x\) 和 \(\sum y\) ...

  4. bzoj 2395 [Balkan 2011]Timeismoney——最小乘积生成树

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2395 如果把 \( \sum t \) 作为 x 坐标,\( \sum c \) 作为 y ...

  5. P5540-[BalkanOI2011]timeismoney|最小乘积生成树【最小生成树,凸壳】

    正题 题目链接:https://www.luogu.com.cn/problem/P5540 题目大意 给出\(n\)个点\(m\)条边边权是一个二元组\((a_i,b_i)\),求出一棵生成树最小化 ...

  6. 洛谷 P5540 - [BalkanOI2011] timeismoney | 最小乘积生成树(最小生成树)

    洛谷题面传送门 大概是一个比较 trivial 的小 trick?学过了就不要忘了哦( 莫名奇妙地想到了 yyq 的"hot tea 不常有,做过了就不能再错过了" 首先看到这种二 ...

  7. HDU5697 刷题计划 dp+最小乘积生成树

    分析:就是不断递归寻找靠近边界的最优解 学习博客(必须先看这个): 1:http://www.cnblogs.com/autsky-jadek/p/3959446.html 2:http://blog ...

  8. 【算法】最小乘积生成树 & 最小乘积匹配 (HNOI2014画框)

    今天考试的时候果然题目太难于是我就放弃了……转而学习了一下最小乘积生成树. 最小乘积生成树定义: (摘自网上一篇博文). 我们主要解决的问题就是当k = 2时,如何获得最小的权值乘积.我们注意到一张图 ...

  9. Luogu5540 最小乘积生成树

    Luogu5540 最小乘积生成树 题目链接:洛谷 题目描述:对于一个\(n\)个点\(m\)条边的无向连通图,每条边有两个边权\(a_i,b_i\),求使\((\sum a_i)\times (\s ...

随机推荐

  1. Idea 使用的技巧和设置

    1.自动提示时候,忽绿大小写, setting---->sensitive 2:IntelliJ IDEA报错class is never used 图中的unused declaration选 ...

  2. JavaScript 中 onload 事件绑定多个方法的优化建议

    页面加载完毕时会触发 onload 事件.基于内容(HTML)要与行为(JavaScript)分离的编码思想,我们需要将一些对页面的初始化操作写在方法内,并通过window.onload = func ...

  3. centos 安装Phpstorm

    下载: http://www.jetbrains.com/phpstorm/download/#section=linux 解压: tar -zxf PhpStorm-8.0.1.tar.gz # 然 ...

  4. Java中的String,StringBuilder,StringBuffer三者的区别(转发:https://www.cnblogs.com/su-feng/p/6659064.html)

    最近在学习Java的时候,遇到了这样一个问题,就是String,StringBuilder以及StringBuffer这三个类之间有什么区别呢,自己从网上搜索了一些资料,有所了解了之后在这里整理一下, ...

  5. Swap file "/etc/.hosts.swp" already exists! [O]pen Read-Only, (E)dit anyway, (R)ecover, (D)elete it,

    非正常关闭vi编辑器时会生成一个.swp文件 非正常关闭vi编辑器时会生成一个.swp文件 关于swp文件 使用vi,经常可以看到swp这个文件,那这个文件是怎么产生的呢,当你打开一个文件,vi就会生 ...

  6. js之Date(日期对象)

    通过日期对象我们可以进行一些对日期时间的操作处理 一.日期对象的创建: var myDate=new Date() 二.Date对象方法: Link:http://www.w3school.com.c ...

  7. 【leetcode刷题笔记】Same Tree

    Given two binary trees, write a function to check if they are equal or not. Two binary trees are con ...

  8. stm32非操作系统开发和带uCos的开发的区别,及一些解析

    从文件角度来看core_cm4.h和stm32f4xx.h分别从内核寄存器和外设寄存器来定义其地址和结构体,是用c语言访问硬件必须的文件,所以这两个文件不论是否带操作系统,都是必须包含进工程的. re ...

  9. jQuery图片水平滑动延迟加载动画

    在线演示 本地下载

  10. Kuhn-Munkres算法 (剪辑)(备用)

    KM算法是通过给每个顶点一个标号(叫做顶标)来把求最大权匹配的问题转化为求完备匹配的问题的. 设顶点Xi的顶标为A[i],顶点Yi的顶标为B[i],顶点Xi与Yj之间的边权为w[i,j]. 在算法执行 ...