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

相关文章

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

springboot如何通过http动态操作xxl-job任务

《springboot如何通过http动态操作xxl-job任务》:本文主要介绍springboot如何通过http动态操作xxl-job任务的问题,具有很好的参考价值,希望对大家有所帮助,如有错... 目录springboot通过http动态操作xxl-job任务一、maven依赖二、配置文件三、xxl-

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降序排序并取第一条示例代码解