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

前言

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

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

一、分治算法是什么?

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

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

二、分治算法的基本思想

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

运行说明:

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

运行结果:

总结算法设计思路

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

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

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

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

  1. 分治算法兵乓球比赛日程(java)

    分治算法之兵乓球比赛日程 分治算法的基本思想是将一个规模为N的问题分解为K个规模较小的子问题,这些子问题相互独立且与原问题性质相同.求出子问题的解,就可得到原问题的解.也就是字面上的解释是" ...

  2. 算法高级(40)-基于分治算法完美解决的人类基因组计划

    一.人类基因组计划 人类基因组计划(英语:Human Genome Project, HGP)是一项规模宏大,跨国跨学科的科学探索工程.其宗旨在于测定组成人类染色体(指单倍体)中所包含的30亿个碱基对 ...

  3. java 比赛赛程_分治算法兵乓球比赛日程(java)

    分治算法之兵乓球比赛日程 分治算法的基本思想是将一个规模为N的问题分解为K个规模较小的子问题,这些子问题相互独立且与原问题性质相同.求出子问题的解,就可得到原问题的解.也就是字面上的解释是" ...

  4. 【选址优化】基于粒子群算法求解配电网抢修选址优化问题含Matlab源码

    1 简介 基于粒子群算法求解配电网抢修选址优化问题​. 2 部分代码 function DrawCircle(Circle1, Circle2, r, 3600, s)​plot(model.trou ...

  5. 粒子群算法java_基于粒子群算法求解求解TSP问题(JAVA)

    一.TSP问题 TSP问题(Travelling Salesman Problem)即旅行商问题,又译为旅行推销员问题.货郎担问题,是数学领域中著名问题之一.假设有一个旅行商人要拜访n个城市,他必须选 ...

  6. 分治算法,动态规划算法和贪心算法的区别和联系

    分治算法,动态规划算法和贪心算法的区别和联系 (一)分治算法 分治算法为什么叫分治算法? 分治这个名字可以分成两部: 第一部分是分,表示把一个原问题分解成很多个小问题,逐个解决; 第二部分是治, 表示 ...

  7. 五大常用算法之一——分治算法

    分治算法(Divide and Conquer) 分治算法,简单理解就是把一个大规模的问题分成相同或者相似的子问题,直到最后子问题能很容易的求解,原问题的解通过子问题的解合并得到. 根据这个描述,我们 ...

  8. 数据结构与算法_03_分而治之的分治算法

    数据结构与算法,系列文章传送地址,请点击本链接. 目录 一.如何理解分治算法 二.分治算法需要满足的条件 三.分治算法--代码模板 四.案例 五.分治思想在海量数据处理中的应用 一.如何理解分治算法 ...

  9. 【数据结构与算法】【算法思想】分治算法

    贪心算法 回溯算法 分治算法 动态规划 MapReduce本质就是分治算法,是Google大数据处理的三驾马车之一,另外两个是GFS和Bigtable.它在倒排索引,PageRank计算,网页分析等搜 ...

最新文章

  1. YOLOv4没交棒,但YOLOv5来了!
  2. numpy中的cov(方差计算)简单介绍
  3. php 控件 手机触控,html5手机触屏touch事件的详细介绍
  4. 长路漫漫,唯剑作伴--loadView、viewDidLoad及viewDidUnload的关系
  5. std::stack
  6. 【Elasticsearch】elasticsearch 常用 API 介绍
  7. SAP那些事-理论篇-18-如何做SAP售前
  8. android脚本录制非root,Android 自动精灵 V2.13.1 支持脚本录制免ROOT
  9. 解决360浏览器兼容模式不兼容,极速模式兼容问题
  10. IIS部署,发布网站
  11. Windows改装成Linux,Windows系统改装成Linux系统
  12. 如何用几何画板把圆奇数等分
  13. 网易云音乐首页导航样式的实现
  14. android MediaPlayer 源码分析 1
  15. 【电路优化】基于粒子群算法实现18节点电力系统的多目标无功优化附matlab代码
  16. 豆腐西施新传:大学毕业生也去磨豆腐
  17. stegsolve使用方法
  18. MATLAB画分布统计以及正态分布拟合图
  19. git not found解决方法
  20. wps加载项初步开发

热门文章

  1. Android端实时音视频开发指南
  2. 投资股权众筹项目,至少需要关注6个方面
  3. coco2dx c++ HTTP实现
  4. ViewGroup之getScrollX()
  5. ShardedJedisPool 中可用连接数的小bug
  6. RHEL6 下Cfengine V3 安装测试1
  7. 有意思的小学数学竞赛题-2
  8. 2017百度之星资格赛 1003 度度熊与邪恶大魔王
  9. android 滚动尺画到控件中间,android 刻度尺控件实现
  10. asp按时间自动递增编号_约束力最强的手铐——美国ASP钢性手铐