Java基本程序设计结构
一、要求:
1、设平面上有一个m×n 的网格,将左下角的网格点标记为(0,0)而右上角的网格点标记为(m,n)。某人想从(0,0)出发沿网格线行进到达(m,n),但是在网格点(i,j)处他只能向上行进或者向右行进,向上行进的代价为aij(amj =+∞),向右行进的代价是bij(bin =+∞)。试设计一个动态规划算法,在这个网格中为该旅行者寻找一条代价最小的旅行线。
二、先不说别的,上代码
/**
*
*
* 2016.09.08
*/
import java.util.*;
import static java.lang.Math.*;
public class Shiyaner
{
public static void main(String[] args)
{
final int m = 5;
final int n = 5;
// 定义向上,向右的代价,以及最优代价
int[][] Cost = new int[m+1][n+1];
int[][] Down = new int[m][n+1];
int[][] Right = new int[m+1][n];
int count = 0, i = 0, j = 0;
// 随机的产生向上代价数组Above,并输出
for(i = 0; i < m; i++)
for(j = 0; j < n+1; j++)
{
Random rand = new Random();
Down[i][j] = (rand.nextInt(5)+5);
}
System.out.printf("Down:\n");
for(i = 0; i < m; i++)
{
for(j = 0; j < n+1; j++)
{
System.out.printf("%5d", Down[i][j]);
}
System.out.println("\n");
}
// 随机的产生向右代价数组Right,并输出
for(i = 0; i < m+1; i++)
for(j = 0; j < n; j++)
{
Random rand = new Random();
Right[i][j] = (rand.nextInt(5)+5);
}
System.out.printf("Right:\n");
for(i = 0; i < m+1; i++)
{
for(j = 0; j < n; j++)
{
System.out.printf("%5d", Right[i][j]);
}
System.out.println("\n");
}
// 求出最优代价数组Cost并输出
Cost[0][0] = 0;
for(i = 1; i < m+1; i++)
Cost[i][0] = Cost[i-1][0] + Down[i-1][0];
for(j = 1; j < n+1; j++)
Cost[0][j] = Cost[0][j-1] + Right[0][j-1];
for(i = 0; i < m; i++)
for(j = 0; j < n; j++)
Cost[i+1][j+1] = min((Cost[i+1][j] + Right[i+1][j]), (Cost[i][j+1] +
Down[i][j+1]));
System.out.printf("最优距离:\n");
for(i = 0; i < m+1; i++)
{
for(j = 0; j < n+1; j++)
{
System.out.printf("%5d",Cost[i][j]);
}
System.out.println("\n");
}
// 输出最优路径的具体走法
System.out.println("请输入你想到达的坐标位置:");
Scanner in1 = new Scanner(System.in);
System.out.print("横坐标:");
int a = in1.nextInt();
System.out.print("纵坐标:");
int b = in1.nextInt();
int[] d = new int[a+b];
int k = a+b-1;
i = a - 1 ;
j = b - 1 ;
while ( i != 0 && j != 0 )
{
if ( Cost[i+1][j+1] == (Cost[i+1][j] + Right[i+1][j]))
{
d[k] = 0;
j--;
k--;
}
else
{
d[k] = 1;
i--;
k--;
}
}
if( i == 0 )
{
while ( j != 0 )
{
d[k] = 1;
j--;
k--;
}
}
if( j == 0 )
{
while ( i != 0 )
{
d[k] = 0;
i--;
k--;
}
}
for (i = a+b-1 ; i >= 0 ; i-- )
{
if ( d[i] == 0 )
System.out.println("Right");
else
System.out.println("Down");
}
}
}
运行结果如下:
Down:
5 9 7 6 5 6
8 9 8 5 7 6
9 6 7 9 6 5
9 9 7 5 6 6
5 7 5 9 5 5
Right:
7 7 9 8 8
6 6 5 6 6
8 9 7 9 8
9 7 7 5 8
6 7 7 9 7
6 7 8 5 6
最优距离:
0 7 14 23 31 39
5 11 17 22 28 34
13 20 25 27 35 40
22 26 32 36 41 45
31 35 39 41 47 51
36 42 44 50 52 56
请输入你想到达的坐标位置:
横坐标:3
纵坐标:3
Down
Down
Down
Down
Right
Right
Java基本程序设计结构的更多相关文章
- 7.20实习培训日志-Java基础程序设计结构
Java基础程序设计结构 在 Math 类中,为了达到最快的性能,所有的方法都使用计算机浮点单元中的例程,如果得到一个完全可预测的结果比运行速度更重要的话,那么就应该使用StrictMath类,它使用 ...
- Notes 20180508 : Java基本程序设计结构之关键字与标识符
我们成功书写了HelloWorld后,又深入了解了main函数,提到过main并非是关键字,可什么又是关键字呢?这其实就是这章要研究的内容,本节研究关键字与标识符,在标识符中我们也会讲解一下Java中 ...
- java基本程序设计结构总结
学习一门语言:(1)掌握它的表现形式(2)这些语言什么应用. 1.1关键字 1.关键字是被赋予了特殊含义的单词. 2.关键字特点:关键字所有字母都小写. 3.类名的每一个单词开头必须大写. 1.2标识 ...
- [JAVA学习笔记]JAVA基本程序设计结构
一个简单的Java应用程序 public class FirstSample { public static void main(String[] args) { System.out.println ...
- 201671010142 Java基本程序设计结构学习的感悟
1.在课堂检测过程中发现自己很大的问题,有些是在学习c语言时就遗留下来的问题,比如对于自加自减,强制类型转换的问题,在Java中又多了一个数据类型就是字节型,而且当字节想加就会自动生成int型,必须进 ...
- java核心技术 第3章 java基本程序设计结构
类名规范:以大写字母开头的名词 若由多个单词组成 每个单词的第一个字母应大写(驼峰命名法) 与.java文件名相同 运行程序:java ClassName(dos命令) 打印语句:System.ou ...
- 201771010117马兴德 实验二 Java基本程序设计(1)
实验二 Java基本程序设计(1) 第一部分 理论知识的学习. 第三章Java基本程序设计结构 1 基本知识: (1)标识符:标识符由字母.下划线.美元符号和数字组成,且第一个符号不能为数字 ...
- Java核心技术卷一基础知识-第3章-Java的基本程序设计结构-读书笔记
第3章 Java的基本程序设计结构 本章内容: 一个简单的Java应用程序 字符串 注释 输入输出 数据类型 控制流 变量 大数值 运算符 数组 本章主要讲述程序设计相关的基本概念(如数据类型.分支以 ...
- 201771010142 张燕 Java的基本程序设计结构第二周学习总结
第三章 Java的基本程序设计结构 第一部分 理论知识学习部分 一 基本知识: 1.标识符:由字母.下划线,美元符号和数字组成,第一个符号不能为数字,可以用作类名.变量名.方法名.数组名和文件名等. ...
随机推荐
- 20155238 2016-2017-2 《Java程序设计》第一周学习总结
教材内容总结 浏览教材,根据自己的理解每章提出一个问题 1.Java语言跨平台的依据是什么?标准的出现是否会限制JAVA的开发与发展? 2.怎样理解类?PATH对于Java编写的意义是什么? 3.Ja ...
- 课下测试补交(ch03 ch08)
课下测试补交(ch03 ch08) 课下测试 ch03 1.有关gdb调试汇编,下面说法正确的是(ABCE) A . 可以用disas反汇编当前函数 B . 以16进制形式打印%rax中内容的命令是 ...
- PPAS通过DBLink,访问Oracle数据库
磨砺技术珠矶,践行数据之道,追求卓越价值 回到上一级页面: PostgreSQL基础知识与基本操作索引页 回到顶级页面:PostgreSQL索引页 作者 高健@博客园 luckyjackga ...
- mfc 私有成员
知识点 类的私有成员private 访问类的私有成员 内联函数inline 一.类的私有成员 用private定义的(变量)或者(函数)只能在本类中使用其他类不能中不能调用: 用public定义的(变 ...
- 当使用了相对路径 <base href="<%= basePath %>" /> 后,全局都只能使用相对路径
<% String path = request.getContextPath(); String basePath = request.getScheme() + "://" ...
- 开源项目CIIP(企业信息管理系统框架).2018.1.0910版更新介绍-上周工作总结
又狂撸了一周的代码.简化了0904版本的多数操作. 上一次更新时,总共需要10步,这次简化成3步.嗯嗯,自我感觉不错. 重要的:在创建项目时,可以选择常用模块啦! 第一步:启动CIIP.Designe ...
- Linux shell(4)
test比较两个值: 测试比较两个值是linux中常用的比较运算,test命令可以进行对两个值的比较,如果比较成功则返回值为0,否则为非0 常用比较方法: ·1.整数比较 2.字符串比较 3.逻辑比较 ...
- Jmeter接口测试(八)cookie设置
HTTP Cookie 管理器 如果你有一个 HTTP 请求,其返回结果里包含一个 cookie,那么 使用 JmeterCookie 管理器会自动将该 cookie保存起来,而且以后所有对该网站的请 ...
- 第四篇 HTTP请求返回状态码收集及解释
[转载]https://blog.csdn.net/wangsen2235068/article/details/8081274 当用户试图通过 HTTP 访问一台正在运行 Internet 信息服务 ...
- Unity优化方向——优化Unity游戏中的垃圾回收(译)
介绍 当我们的游戏运行时,它使用内存来存储数据.当不再需要该数据时,存储该数据的内存将被释放,以便可以重用.垃圾是用来存储数据但不再使用的内存的术语.垃圾回收是该内存再次可用以进行重用的进程的名称. ...