java动态规划问题
这里是简单的动态规划问题。其实,如果我们学过数据结构,应该就接触过动态规划问题,当时一直没有反应过来。我们求最小生成树用的是贪婪算法。而求最短路径就是动态规划。从一个点出发,到另外每个点的最短距离。在求最短路径问题中,取一点,然后与选取与这个点连接的,最小的一条边,把这个点标上,然后求与标上点的连接的点的最短路径。我们先来看这道题目吧
1.题目描述
将一个由N行数字组成的三角形,如图所以,设计一个算法,计算出三角形的由顶至底的一条路径,使该路径经过的数字总和最小。
我们可以把这个横过来看变成
7
3 4
8 5 0
2 7 4 4
4 5 2 6 5
从顶部到底部,只能从7走到3,或者8,然后从3走到8和1,8走到1和0 。。。。
我们自己计算最小路径怎么算呢。假如从7出发,我们选择与他们两个的最长的一个,这是贪婪法,但是贪婪法有些时候不适用,比如这个图,7的话,贪婪选最小的选3,但是最短路径不是这条。
这道题目就要用到动态规划,我从底到顶部,依次求出从底部到上一层的最短路求出来。每次求最短路径,再记录下来就行。这道题目简单的地方就是上层的点到下层的路只有两条。
也就是说共有5层,用一个tem[][]来存放从底层到这个点的最短路径,那么第5层从底到自己最短路径还是本身,4,5,2,6,5。第四层的就是temp[4][j] = temp[4][j] + Min{temp[5][j],temp[5][j+1]},只有这两条路与上一层直接相连,就能直接标上。同理递归调用。。。
2.输入描述
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5
3.输出描述:
输出每个点的从底部到这一点的最短路径,都记录下来。
17
10 14
14 7 6
6 9 6 9
4 5 2 6 5
4.代码示例:
package a; import java.util.Scanner; public class DP {
static int qipan[][] = new int[5][5];
static int temp[][] = new int[5][5]; //用来存放的最短路径的
public static void main(String[] args) {
Scanner scn = new Scanner(System.in);
for(int i=0;i<5;i++) {
for(int j=0;j<=i;j++) {
qipan[i][j] = scn.nextInt();
temp[i][j] = qipan[i][j];
}
}
dp(qipan,4);//把棋盘的第5层开始求。第5层最短路是本身,数组下标是4 //输出棋盘
for(int i=0;i<5;i++) {
for(int j=0;j<=i;j++) {
System.out.printf("%-4d",temp[i][j]);
}
System.out.println();
} //输出路径,这部分代码只是用来输出路径的,调用print路径
temp[0][0] = -1;
print(temp,0);
for(int i=0;i<5;i++) {
for(int j=0;j<=i;j++) {
if(temp[i][j] ==-1) {
System.out.printf("%-4d",qipan[i][j]);
}else {
System.out.printf("%-4d",0);
} }
System.out.println();
}
}
private static void print(int[][] temp, int k) { if( k==4 ) {
return;
}
for(int i=0;i<=k;i++) {
if(temp[k][i]==-1) {
if(temp[k+1][i]<temp[k+1][i+1]) {
temp[k+1][i] = -1;
}else {
temp[k+1][i+1] = -1;
}
}
}
print(temp, k+1);
}
private static void dp(int[][] qipan, int k) {
if(k ==0) {
return;
}
for(int j=0;j<k;j++) {
temp[k-1][j] = temp[k-1][j] + Math.min(temp[k][j], temp[k][j+1]);
}
dp(qipan, k-1);
}
}
java动态规划问题的更多相关文章
- java动态规划取硬币问题
最近一直在研究动态规划的问题.今天遇到了取硬币问题. 其实动态规划还是,我从底部向顶部,依次求出每个状态的最小值,然后就可以标记上. 这道题目就是,假如有1,5,7,10这四种币值的硬币,我取14元, ...
- Java动态规划
1. 介绍 动态规划典型的被用于优化递归算法,因为它们倾向于以指数的方式进行扩展.动态规划主要思想是将复杂问题(带有许多递归调用)分解为更小的子问题,然后将它们保存到内存中,这样我们就不必在每次使用它 ...
- java 动态规划解决最大连续子数列和
很多动态规划算法非常像数学中的递推.我们如果能找到一个合适的递推公式,就能很容易的解决问题.我们用dp[n]表示以第n个数结尾的最大连续子序列的和,这里第n个数必须在子序列中.于是存在以下递推公式: ...
- java动态规划导弹问题
这是一道动态规划题,和昨天的取硬币还有最长公共字串有点类似. 1.题目描述: 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一 ...
- Java动态规划实现最短路径问题
问题描述 给定一个加权连通图(无向的或有向的),要求找出从每个定点到其他所有定点之间的最短路径以及最短路径的长度. 2.1 动态规划法原理简介 动态规划算法通常用于求解具有某种最优性质的问题.在这类问 ...
- 划分问题(Java 动态规划)
Description 给定一个正整数的集合A={a1,a2,-.,an},是否可以将其分割成两个子集合,使两个子集合的数加起来的和相等.例A = { 1, 3, 8, 4, 10} 可以分割:{1, ...
- 算法:矩阵连乘(Java)动态规划
Description 给你2个矩阵A.B,我们使用标准的矩阵相乘定义C=AB如下: A数组中栏(column)的数目一定要等于B数组中列(row)的数目才可以做此2数组的相乘.若我们以rows(A) ...
- java 动态规划解决上楼梯问题
问题描述: 你正在爬楼梯. 它需要n步才能达到顶峰. 每次你可以爬1或2步. 您可以通过多少不同的方式登顶? 注意:给定n将是一个正整数. Example 1: Input: 2 Output: 2 ...
- [leetcode] 45. 跳跃游戏 II(Java)(动态规划)
45. 跳跃游戏 II 动态规划 此题可以倒着想. 看示例: [2,3,1,1,4] 我们从后往前推,对于第4个数1,跳一次 对于第3个数1,显然只能跳到第4个数上,那么从第3个数开始跳到最后需要两次 ...
随机推荐
- Linux 错误码对照表
errno 在 <errno.h> 中定义,错误 Exx 的宏定义在 /usr/include/asm-generic 文件夹下面的 errno-base.h 和 errno.h,分别定 ...
- java nio和bio
理解同步/异步,阻塞/非阻塞:https://juejin.im/entry/598da7d16fb9a03c42431ed3 2:http://qindongliang.iteye.com/blog ...
- idea创建文件类型失败(xml之类的失效
https://blog.csdn.net/sutongxuevip/article/details/72832754
- Kafka之sync、async以及oneway
kafka有同步(sync).异步(async)以及oneway这三种发送方式,某些概念上区分也可以分为同步和异步两种,同步和异步的发送方式通过“producer.type”参数指定,而oneway由 ...
- ubuntu15.10下code::blocks设置运行窗口为gnome命令行
code::blocks编译运行C++程序(F9)默认出现的运行串口在有鼠标的情况下进行粘贴还是很方便的,只要按下鼠标滑轮,位与剪切板中的数据就能粘贴到运行串口中. 但是对于用笔记本而且没有鼠标地童鞋 ...
- 部署docker
部署和开发环境不一样,我们不需要频繁地进入到容器内部,所以一般我们会将代码和环境打包到一块,部署到服务器上 Clone 代码 将项目代码克隆到本地 git clone git@git.coding.n ...
- TCP/IP网络编程系列之四(初级)
TCP/IP网络编程系列之四-基于TCP的服务端/客户端 理解TCP和UDP 根据数据传输方式的不同,基于网络协议的套接字一般分为TCP和UDP套接字.因为TCP套接字是面向连接的,因此又称为基于流的 ...
- HBase之八--(2):HBase二级索引之Phoenix
1. 介绍 Phoenix 是 Salesforce.com 开源的一个 Java 中间件,可以让开发者在Apache HBase 上执行 SQL 查询.Phoenix完全使用Java编写,代码位于 ...
- OSGi学习-总结
本文是osgi实战一书的前几章读书总结 1. OSGi简介 Java缺少对高级模块化的支持,为了弥补Java在模块化方面的不足,大多数管理得当的项目都会要求建立一整套技术,包括: 适应逻辑结构的编程 ...
- 禁用绑定在Repeater的控件
实例一: 前台: <asp:Repeater ID="rp_bf" runat="server" onitemdatabound="rp_bf_ ...