选址问题java_学习使用分治算法来解决邮局选址问题(Java实现)

邮局选址问题(分治算法)

前言

提示:在算法的学习过程中我们会遇到各种各样的算法思想,其中最常见的就有分治算法思想,而本文的问题邮局选址问题就是基于分治思想而去实现的一个日常问题

提示:以下是本文内容,我将对该问题进行详细的描述

一、分治算法是什么?

总体而言,分治算法是将一个难以直接解决的规模较大的问题分解为若干个规模较小的子问题,并各个击破,分而治之。

23aad313f182993d69e4f138c9ef0932.png

将求出的较小规模的问题解合并成一个较大规模的问题解,并自底向上地求出原问题的解。

cd1369848cc142d5ae6f51931876f30a.png

二、分治算法的基本思想

1.分治策略的基本思想

1.将原始问题划分或者归结为规模较小的子问题 2.递归或迭代求解每个子问题 3.将子问题的解综合得到原问题的解

2.注意:

1.子问题与原始问题性质完全一样

2.子问题之间可彼此独立地求解

3.递归停止时子问题可直接求解

三、邮局选址问题

问题描述:

在一个按照东西和南北方向划分成规整街区的城市里,n个居民点散乱地分布在不同的街区中。用x坐标表示东西向,用y坐标表示南北向。各居民点的位置可以由坐标(x,y)表示。要求:为建邮局选址,使得n个居民点到邮局之距离的总和最小。

提示:

带权中位数

代码实现 :

package Site_selection;

import java.io.BufferedReader;

import java.io.FileReader;

public class Site_selection {

public static void main(String[] args) {

// TODO Auto-generated method stub

int N=0;

int x[]=new int[500]; //存放测试样本中x轴的数据值

int y[]=new int[500]; int xweight[]=new int[500];//存放测试样本中的权值

int yweight[]=new int[500]; for(int a=1;a<7;a++) { try { System.out.println("测试样本"+a); FileReader filereader=new FileReader("input0"+a+".txt"); //采用拼接方式读取样本 BufferedReader buf=new BufferedReader(filereader); int j=0; String readline=""; String[] array=new String[200]; readline=buf.readLine(); N=Integer.parseInt(readline);//读取测试样本中的第一行居民点的个数 System.out.println("居民点个数为:"+N); while((readline=buf.readLine())!=null) { array=readline.split(","); //按照,分隔字符串来放入相应的数组之中 x[j]=Integer.parseInt(array[0]); y[j]=Integer.parseInt(array[1]); xweight[j]=Integer.parseInt(array[2]); yweight[j]=Integer.parseInt(array[2]); j++; } } catch(Exception e) { e.printStackTrace(); } MinSumDistance(x,y,xweight,yweight,N); }

}

/*

* 1.快速排序

* 通过该排序方式中的分治思想,来对测试样本中所有的数据值进行相对应的排序

*

*/ public static void QuickSort(int a[],int weight[],int low,int high){ if(low>high) { return; } int first=low; int last=high; int key=a[first]; int Weight=weight[first]; while(firstkey) { --last; } a[first]=a[last]; weight[first]=weight[last]; while(first= sumxweight / 2){x1=i;break;//求取x轴上的带权中位数 } } System.out.println("邮局的x坐标为:"+x[x1]); QuickSort(y,yweight,0,N-1); int sumyWeight=0; for(int b=0;b= sumyweight / 2){y1=k;break;//求取y轴上的带权中位数 } } System.out.println("邮局的y坐标为:"+y[y1]); System.out.println("邮局的坐标位置为"+x[x1]+","+y[y1]); for(int q=0;q

}1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

运行说明:

邮局选址问题通过对居民点的坐标位置已经居民数量权值来进行分析,在输入数据中,先输入该测试样例共有几个居民点,再依次输入各个居民点的坐标位置以及居民的数量,运行程序之后会返回输出结果邮局所在的坐标位置,以及邮局到所有居民点的最短路径之和。

运行结果:

af81f6c0767d97d4f2886d4056447b5e.png

总结算法设计思路

该程序主要采用了分治的思想,包含有快速排序的方法,将所输入数据值中的x坐标按从小到大依次进行排序,使得该x坐标相对应的权值也进行相应的排序。然后通过权值的总和一半来选择所对应的x坐标,求出带权中位数,并通过同样的方式求出数据y坐标,最后通过得到的邮局坐标对每一居民点坐标进行求距离操作,所累加的结果就是邮局到所有居民点的最短距离之和。

文章来源: blog.csdn.net,作者:九墨、,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/Xiao_ni_tongxue/article/details/109255860

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/436242.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

WinAPI: GetCurrentThread、GetCurrentThreadId、GetCurrentProcess、GetCurrentProcessId

{返回当前线程的虚拟句柄} GetCurrentThread: THandle;{返回当前线程 ID} GetCurrentThreadId: DWORD;{返回当前进程的虚拟句柄} GetCurrentProcess: THandle;{返回当前进程 ID} GetCurrentProcessId: DWORD;提示:ID 是系统唯一的标识.所谓虚拟句柄, 就是该句柄只在调用进程的进…

Windows Embedded CE 6.0开发初体验(一)Windows CE概述

这篇文章的目的并不是介绍Windows Embedded CE开发的方方面面&#xff0c;只是用一个初涉嵌入式领域的软件开发者的视角来介绍Windows CE开发中最常用的概念和知识&#xff0c;解决大家会在实际开发中碰到的一些小问题&#xff0c;让大家了解嵌入式开发与应用程序开发&#xff…

Windows Embedded CE 6.0开发初体验(二)CE开发环境

CE开发环境 下面就要让今天的主角闪亮登场了——Digi CC 9P开发板。为了感谢Digi提供的开发板&#xff0c;还是给他们做个广告吧&#xff1a;这是一家以WiFi相关产品为主营业务的公司&#xff0c;也生产ARM架构的CPU&#xff0c;所以做开发板也是他们公司份内的事情了。总的感…

Windows Embedded CE 6.0开发初体验(三)设置Boot-loader

在Digi CC 9P开发板中已经预置了Boot-loader和一个CE 6.0的系统&#xff0c;所以&#xff0c;我们直接启动开发板&#xff0c;就可以运行一个CE 6.0的操作系统。不过&#xff0c;我们的最终目的是要开发一个自己的CE 6.0平台&#xff0c;所以我们需要对Boot-loader中的一些系统…

【转】C++学习三 模板类出错总结(Missing template arguments before ‘L‘)

一、模板类的说明 模板类有一个好处是可以放宽你输入的数据类型。 比如有这样的一个函数&#xff1a; int add(int x, int y) {return xy; } 这个函数对于int类型的x,y才适合&#xff0c;但是如果我们希望计算float类型的呢&#xff1f; 这必须重新定义一个函数&#xff…

Windows Embedded CE 6.0开发初体验(四)跑个应用程序先

因为我们的开发板上已经预置了Windows CE 6.0的系统&#xff0c;所以我们可以先创建一个.NET CF的应用程序&#xff0c;来看一下如何将.NET CF程序部署到Digi开发板上。 第一步&#xff0c;首先在Visual Studio 2005中创建一个新的工程。这一步和开发普通的Windows Mobile应用…

【转】C++学习四 冒泡排序法的一些改进

冒泡排序法需要两次扫描&#xff0c;所以从时间复杂度来说&#xff0c;是O(n2). 如果用图形表示&#xff0c;是这样的&#xff1a; 但是我们可以加以改进。 首先是&#xff0c;如果在排序中间&#xff0c;整个向量已经达到了有序状态&#xff0c;可以直接跳出来。 这样它的复…

java中的jgroup_JGroups实现聊天小程序

本文实例为大家分享了JGroups实现聊天小程序的具体代码&#xff0c;供大家参考&#xff0c;具体内容如下效果图&#xff1a;代码部分&#xff1a;package com.lei.jgoups;import java.io.BufferedReader;import java.io.DataInputStream;import java.io.DataOutputStream;impor…

Windows Embedded CE 6.0开发初体验(五)构建CE平台

接下来的一节会有非常多的图&#xff0c;因为我们要在Visual Studio 2005里创建一个CE 6.0的平台&#xff08;Platform&#xff09;了。创建CE平台的方法和创建普通工程的方法类似。在完成了Platform Builder之后&#xff0c;我们打开Visual Studio 2005后&#xff0c;选择File…

一步一步学Silverlight 2系列(31):图形图像综合实例—实现水中倒影效果

概述 Silverlight 2 Beta 1版本发布了&#xff0c;无论从Runtime还是Tools都给我们带来了很多的惊喜&#xff0c;如支持框架语言Visual Basic, Visual C#, IronRuby, Ironpython&#xff0c;对JSON、Web Service、WCF以及Sockets的支持等一系列新的特性。《一步一步学Silverlig…

Windows Embedded CE 6.0开发初体验(六)平台定制

Windows CE是一个组件化的操作系统&#xff0c;我们可以根据不同的环境设置不同的组件来组合成有针对性的平台&#xff0c;而一个功能往往需要多个组件才能够实现。Catalog就是实现某个功能的组件集合&#xff0c;每个Catalog Item会包含一个或多个组件&#xff0c;而Catalog I…

【转】Win32 SDK 实现带图片的 Button 控件BM_SETIMAGE(Disable时图片不显示)

在编写对话框程序时&#xff0c;希望能在按钮控件里显示一个小插图,如图所示 最初使用的方法是使用 BM_SETIMAGE 消息&#xff0c;但却不能达到满意的效果&#xff0c;在网上查了一通资料&#xff0c;最后终于实现了&#xff0c;现在把实现的方法记下来。 首先来到MSDN上&…

解读设计模式----命令模式(Command Pattern)

***本文与作者原文有一定的偏差,其中加入了一部分是个人看法,详细请查看作者原文。***原文连接http://www.dofactory.com/Patterns/PatternCommand.aspx命令模式意图&#xff1a;  GOF 在《设计模式》一书中阐述其意图&#xff1a;“将一个请求封装为一个对象&#xff0c;从而…

Windows Embedded CE 6.0开发初体验(七)编译和调试平台

在完成Catalog选择之后&#xff0c;平台定制的工作告一段落&#xff0c;接下来&#xff0c;我们就要进入变数最多的环节——“编译和调试”平台了。编译的操作简单&#xff0c;但是想通过编译却有很多变数。 编译平台的第一步是选择Debug或者Release版本。选择 Build菜单中的C…

python合并单元格 索引_python笔记:纵向合并表格

工作中我们常常遇到多个格式相同的表格面要合并成一个表格&#xff0c;比如将2019年的数据与2020年的数据合并在一起来进行分析。平时EXCEL时我们通常直接复制粘贴&#xff0c;但有时因表格内容过大&#xff0c;直接粘贴效率低&#xff0c;且当字段过多时还需要进行逐列粘取我们…

【转】Win32子窗口控件(按钮、编辑框、静态框、滚动条等)!!

前言&#xff1a; 子窗口控件是特殊的子窗口&#xff0c;不需要我们注册窗口类&#xff0c;系统已经注册好了&#xff0c;我们只需要在创建时选择相应的窗口类名。常用的子窗口控件有按钮BUTTON、组合框COMBOBOX、编辑框EDIT、列表框LISTBOX、静态框STATIC、滚动条SCROLLBAR等类…

在PC上用模拟器搭建Windows Mobile仿真环境:Microsoft Device Emulator使用

因为工作需要&#xff0c;体验了一下微软的移动设备模拟器Device Emulator 3.0。在此把一些使用体验写出来和大家交流一下&#xff0c;在自己摸索过程中从网上找了很多资料参考&#xff0c;希望大家再做这个的时候少走一些弯路%^) 在PC上用模拟器搭建Windows Mobile仿真环境&am…

【转】QT布局QGridLayout QHBoxLayout QVBoxLayout简要分析!!

转自&#xff1a;https://blog.csdn.net/sabcdefg/article/details/106693203 在分析之前,先吐槽下M$的MFC,竟然没有相对布局!(至少我不知道,每次都是使用代码控制布局), M$这么多年,也不发展一下,你看C#都有相对布局... 参考精通Qt4编程&#xff08;第2版&#xff09;,先看看…

php下拉选项登录_php下拉选项的批量操作的实现代码

实现功能&#xff0c;操作项可以单独删除&#xff0c;批量项可以批量删除&#xff0c;批量显示&#xff0c;隐藏(改广告的数据库的status_is的值)&#xff1b;1.视图关键点&#xff1a;<?php echo $row->id?>全选选择操作删除显示隐藏/*单个删除*/2.控制器&#xff…

协议栈开发学习总结

近来一直很少些关于技术方面的文章&#xff0c;一来是被工作和生活所累&#xff0c;没有很多闲暇多余的时间,二来呢是觉得一直没有好的case&#xff0c;或则有好的case&#xff0c;但觉得目前在这个case方面&#xff0c;自己还不算很professional。今天心情不错&#xff0c;感觉…