数据结构和算法—用动态规划求解最短路径问题
在利用动态规划求解的过程中值得注意的就是是否包含最优子结构,简单来讲就是一个问题的最优解是不是包含着子问题的最优解。利用求解子问题的最优解最后得到整个问题的最优解,这是利用动态规划求解问题的基本前提。
二、最短路径问题
现有一张地图,各结点代表城市,两结点间连线代表道路,线上数字表示城市间的距离。如图1所示,试找出从结点A到结点E的最短距离。
图 1
三、利用动态规划求解最短路径问题
数据结构和算法—用动态规划求解最短路径问题
在解决这个问题的过程中,我其实是在尝试着使用不同的工具,首先我想对这种图处理,我使用了Gephi,Gephi是我在学习复杂网络的时候学会的一个工具,这个工具可以很方便的处理网络数据,能够动态的生成图的结构,下面是我用Gephi画出的图:
图 2
Gephi的另一个比较重要的工具就是可以在生成图的过程中,将图的数据导出,导出的数据可以方便的使用。
还是重点说说我是怎么利用动态规划的思想去求解这样的最短路径问题的:
1、描述最优解的结构
要使得从0到10的距离最短,令为到第个节点的最短距离,则,用同样的方法可以求得等。数据分析师培训
2、递归定义最优解的值
其中表示与边有连接的节点,而且。
3、按自底向上的方式计算每个节点的最优值
此时我们就得利用递归公式分别求解,这样最终便能得到最终的解。
结果为:
JAVA实现:
[java] view plain copy 在CODE上查看代码片派生到我的代码片
package org.algorithm.dynamicprogramming;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.io.Reader;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Stack;
/**
* 利用动态规划求解最短路径问题
*
* @author dell
*
*/
public class CalMinDistance {
// 计算最短的距离
public static int[] calMinDistance(int distance[][]) {
int dist[] = new int[distance.length];
dist[0] = 0;
for (int i = 1; i < distance.length; i++) {
int k = Integer.MAX_VALUE;
for (int j = 0; j < i; j++) {
if (distance[j][i] != 0) {
if ((dist[j] + distance[j][i]) < k) {
k = dist[j] + distance[j][i];
}
}
}
dist[i] = k;
}
return dist;
}
// 计算路径
public static String calTheRoute(int distance[][], int dist[]) {
Stack<Integer> st = new Stack<Integer>();
StringBuffer buf = new StringBuffer();
int j = distance.length - 1;
st.add(j);// 将尾插入
while (j > 0) {
// int num = 0;
for (int i = 0; i < j; i++) {
if (distance[i][j] != 0) {
// num++;
if (dist[j] - distance[i][j] == dist[i]) {
st.add(i);
}
}
}
j = st.peek();
}
while (!st.empty()) {
buf.append(st.pop()).append("-->");
}
return buf.toString();
}
// 读取文件
@SuppressWarnings("resource")
public static int[][] readTheFile(File f) {
Reader input = null;
try {
input = new FileReader(f);
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
BufferedReader buf = null;
buf = new BufferedReader(input);
List<String> list = new ArrayList<String>();
try {
String str = buf.readLine();
while (str != null) {
list.add(str);
str = buf.readLine();
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Iterator<String> it = list.iterator();
int distance[][] = new int[11][11];
while (it.hasNext()) {
String str1[] = it.next().split(",");
int i = Integer.parseInt(str1[0]);
int j = Integer.parseInt(str1[1]);
distance[i - 1][j - 1] = Integer.parseInt(str1[2]);
}
return distance;
}
public static void main(String args[]) {
// 读文件
File f = new File("D:" + File.separator + "distance_1.csv");
int distance[][] = readTheFile(f);
int dist[] = calMinDistance(distance);
System.out.println("最短路径长度为:" + dist[distance.length - 1]);
System.out.println("最短路径为:" + calTheRoute(distance, dist));
}
}
数据分析咨询请扫描二维码
需求持续增长 - 未来数据分析师需求将持续上升,企业对数据驱动决策的依赖加深。 - 预测到2025年,中国将需要高达220万的数据人 ...
2024-11-22《Python数据分析极简入门》 第2节 4 Pandas条件查询 在pandas中,可以使用条件筛选来选择满足特定条件的数据 importpanda ...
2024-11-22数据分析师的工作内容涉及多个方面,主要包括数据的收集、整理、分析和可视化,以支持商业决策和问题解决。以下是数据分析师的一 ...
2024-11-21数据分析师必须掌握的技能可以从多个方面进行归纳和总结。以下是数据分析师需要具备的主要技能: 统计学基础:数据分析师需要 ...
2024-11-21数据分析入门的难易程度因人而异,总体来看,入门并不算特别困难,但需要一定的学习和实践积累。 入门难度:数据分析入门相对 ...
2024-11-21数据分析是一项通过收集、整理和解释数据来发现有用信息的过程,它在现代社会中具有广泛的应用和重要性。数据分析能够帮助人们更 ...
2024-11-21数据分析行业正在迅速发展,随着技术的不断进步和数据量的爆炸式增长,企业对数据分析人才的需求也与日俱增。本文将探讨数据分析 ...
2024-11-21数据分析的常用方法包括多种技术,每种方法都有其特定的应用场景和优势。以下是几种常见的数据分析方法: 对比分析法:通过比 ...
2024-11-21企业数字化转型是指企业利用数字技术对其业务进行改造和升级,以实现提高效率、降低成本、创新业务模式等目标的过程。这一过程不 ...
2024-11-21数据分析作为一个备受追捧的职业领域,吸引着越来越多的女性加入其中。对于女生而言,在选择成为一名数据分析师时,行业选择至关 ...
2024-11-21大数据技术专业主要学习计算机科学、数学、统计学和信息技术等领域的基础理论和技能,旨在培养具备大数据处理、分析和应用能力的 ...
2024-11-21《Python数据分析极简入门》 第2节 3 Pandas数据查看 这里我们创建一个DataFrame命名为df: importnumpyasnpi ...
2024-11-21越老越吃香的行业主要集中在需要长时间经验积累和专业知识的领域。这些行业通常知识更新换代较慢,因此随着年龄的增长,从业者能 ...
2024-11-20数据导入 使用pandas库的read_csv()函数读取CSV文件或使用read_excel()函数读取Excel文件。 支持处理不同格式数据,可指定分隔 ...
2024-11-20大数据与会计专业是一门结合了大数据分析技术和会计财务理论知识的新型复合型学科,旨在培养能够适应现代会计业务新特征的高层次 ...
2024-11-20要成为一名数据分析师,需要掌握一系列硬技能和软技能。以下是成为数据分析师所需的关键技能: 统计学基础 理解基本的统计概念 ...
2024-11-20是的,Python可以用于数据分析。Python在数据分析领域非常流行,因为它拥有丰富的库和工具,能够高效地处理从数据清洗到可视化的 ...
2024-11-20在这个数据驱动的时代,数据分析师的角色变得愈发不可或缺。他们承担着帮助企业从数据中提取有价值信息的责任,而这些信息可以大 ...
2024-11-20数据分析作为现代信息时代的支柱之一,已经成为各行业不可或缺的工具。无论是在商业、科研还是日常决策中,数据分析都扮演着至关 ...
2024-11-20数字化转型已成为当今商业世界的热点话题。它不仅代表着技术的提升,还涉及企业业务流程、组织结构和文化的深层次变革。理解数字 ...
2024-11-20