http://poj.org/problem?id=2728最优比例生成树

2024-01-10 08:08

本文主要是介绍http://poj.org/problem?id=2728最优比例生成树,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先解决这类问题一般有2种方法,,一是迭代法其次就是二分法,这里用到的主要是逼近的思想,,,

这是题目的要求是一颗生成树,但不是要求边权之和最大,所以不能直接用最小生成树来求,但我们可以把其转发为一个熟悉的问题。

设x1,x2,,,,,xm在集合{0,1}中取值,当且仅当xi=1时表示边i在生成树中出现,我们希望的是r =   ∑(cost[i] * x[i])/∑(benifit[i] * x[i]),r最小,

为了使r最小我们设计一个子问题z=∑(cost[i] * x[i])-l*∑(benifit[i] * x[i])  = ∑(d[i] * x[i])最小,而d[i]=( cost[i]-l*benifit[i])就可以转发为以d[i]为i边的权值且满足最小生成树为0时所对应的l为就是所求的生成树的最优比,,,,


迭代法代码:

#include<stdio.h>
#include<math.h>
#include<string.h>
#define   Maxvalue 99999999
int n,x[1000],y[1000],h[1000];
double cost[1000][1000],dist[1000][1000],dis[1000];
bool flag[1000];
double prim(double p)
{int k=0,pre[1000]={0};double v,totcost=0,totdist=0;memset(flag,false,sizeof(flag));dis[0]=0,flag[0]=true;for (int j=1;j<n;j++)dis[j]=cost[j][0]-p*dist[j][0];for (int i=1;i<n;i++){double mincost=Maxvalue;for (int j=1;j<n;j++)if (flag[j]==false && mincost>dis[j])mincost=dis[k=j];if(!k) break;flag[k]=true;totcost+=cost[pre[k]][k];totdist+=dist[pre[k]][k];for (int j=0;j<n;j++)if (!flag[j]&&((v=cost[k][j]-p*dist[k][j])<dis[j]))dis[j]=v,pre[j]=k;}return totcost/totdist;
}int main()
{int i,j;double a,b;while(scanf("%d",&n)==1&&n){for (i=0;i<n;i++)scanf("%d%d%d",&x[i],&y[i],&h[i]);for (i=0;i<n-1;i++){for (j=i+1;j<n;j++){b=(x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j]);dist[i][j]=sqrt(b);dist[j][i]=dist[i][j];cost[i][j]=h[i]-h[j];if (cost[i][j]<0)cost[i][j]=-cost[i][j];cost[j][i]=cost[i][j];}}a=0.0;while (1){b=prim(a);if (fabs(b-a)<0.0001)break;a=b;}printf("%.3lf\n",b);}return 0;
}



这篇关于http://poj.org/problem?id=2728最优比例生成树的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/590124

相关文章

Maven 配置中的 <mirror>绕过 HTTP 阻断机制的方法

《Maven配置中的<mirror>绕过HTTP阻断机制的方法》:本文主要介绍Maven配置中的<mirror>绕过HTTP阻断机制的方法,本文给大家分享问题原因及解决方案,感兴趣的朋友一... 目录一、问题场景:升级 Maven 后构建失败二、解决方案:通过 <mirror> 配置覆盖默认行为1. 配置示

Springboot3+将ID转为JSON字符串的详细配置方案

《Springboot3+将ID转为JSON字符串的详细配置方案》:本文主要介绍纯后端实现Long/BigIntegerID转为JSON字符串的详细配置方案,s基于SpringBoot3+和Spr... 目录1. 添加依赖2. 全局 Jackson 配置3. 精准控制(可选)4. OpenAPI (Spri

Linux中修改Apache HTTP Server(httpd)默认端口的完整指南

《Linux中修改ApacheHTTPServer(httpd)默认端口的完整指南》ApacheHTTPServer(简称httpd)是Linux系统中最常用的Web服务器之一,本文将详细介绍如何... 目录一、修改 httpd 默认端口的步骤1. 查找 httpd 配置文件路径2. 编辑配置文件3. 保存

Python实现自动化Word文档样式复制与内容生成

《Python实现自动化Word文档样式复制与内容生成》在办公自动化领域,高效处理Word文档的样式和内容复制是一个常见需求,本文将展示如何利用Python的python-docx库实现... 目录一、为什么需要自动化 Word 文档处理二、核心功能实现:样式与表格的深度复制1. 表格复制(含样式与内容)2

python如何生成指定文件大小

《python如何生成指定文件大小》:本文主要介绍python如何生成指定文件大小的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python生成指定文件大小方法一(速度最快)方法二(中等速度)方法三(生成可读文本文件–较慢)方法四(使用内存映射高效生成

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

MySQL查看表的最后一个ID的常见方法

《MySQL查看表的最后一个ID的常见方法》在使用MySQL数据库时,我们经常会遇到需要查看表中最后一个id值的场景,无论是为了调试、数据分析还是其他用途,了解如何快速获取最后一个id都是非常实用的技... 目录背景介绍方法一:使用MAX()函数示例代码解释适用场景方法二:按id降序排序并取第一条示例代码解

MybatisX快速生成增删改查的方法示例

《MybatisX快速生成增删改查的方法示例》MybatisX是基于IDEA的MyBatis/MyBatis-Plus开发插件,本文主要介绍了MybatisX快速生成增删改查的方法示例,文中通过示例代... 目录1 安装2 基本功能2.1 XML跳转2.2 代码生成2.2.1 生成.xml中的sql语句头2

C++ HTTP框架推荐(特点及优势)

《C++HTTP框架推荐(特点及优势)》:本文主要介绍C++HTTP框架推荐的相关资料,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Crow2. Drogon3. Pistache4. cpp-httplib5. Beast (Boos

SpringBoot中HTTP连接池的配置与优化

《SpringBoot中HTTP连接池的配置与优化》这篇文章主要为大家详细介绍了SpringBoot中HTTP连接池的配置与优化的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、HTTP连接池的核心价值二、Spring Boot集成方案方案1:Apache HttpCl