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

相关文章

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

使用Python的requests库来发送HTTP请求的操作指南

《使用Python的requests库来发送HTTP请求的操作指南》使用Python的requests库发送HTTP请求是非常简单和直观的,requests库提供了丰富的API,可以发送各种类型的HT... 目录前言1. 安装 requests 库2. 发送 GET 请求3. 发送 POST 请求4. 发送

C#使用Spire.XLS快速生成多表格Excel文件

《C#使用Spire.XLS快速生成多表格Excel文件》在日常开发中,我们经常需要将业务数据导出为结构清晰的Excel文件,本文将手把手教你使用Spire.XLS这个强大的.NET组件,只需几行C#... 目录一、Spire.XLS核心优势清单1.1 性能碾压:从3秒到0.5秒的质变1.2 批量操作的优雅

Python使用python-pptx自动化操作和生成PPT

《Python使用python-pptx自动化操作和生成PPT》这篇文章主要为大家详细介绍了如何使用python-pptx库实现PPT自动化,并提供实用的代码示例和应用场景,感兴趣的小伙伴可以跟随小编... 目录使用python-pptx操作PPT文档安装python-pptx基础概念创建新的PPT文档查看

Java报错:org.springframework.beans.factory.BeanCreationException的五种解决方法

《Java报错:org.springframework.beans.factory.BeanCreationException的五种解决方法》本文解析Spring框架中BeanCreationExce... 目录引言一、问题描述1.1 报错示例假设我们有一个简单的Java类,代表一个用户信息的实体类:然后,

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据