java暴力递归回溯算法
今天这个问题是我之前一直想解决的,还记得以前第一次上蓝桥杯的课的时候,也就是大一高数期中模拟考试那天,下午去上蓝桥杯课,遇到这道题,当时写了写,根本没有思路,然后就给大一的模拟考试去了。印象深刻啊,一直没写出来。先来说一下题目吧。
1.问题描述:
如下图所示的数字三角形,编写一个程序计算从顶部到底部某一处的一条路径,使得该路径数字和最大,输出路径和最大值。
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5
当然什么是路径,路径就是能连着,但是不能跳过,比如7-3-8-7-2就是一条路径。
2.输入:
5 7 3 8 8 1 0 2 7 4 4 4 5 2 6 5
3.输出:
路径:7-3-8-7-5,最大值:30
4.算法思想: 这道题啊,其实和马走日思想很像,首先从0,0这个位置出发,一直走遍整个棋盘(把整体看做一个棋盘)
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5
棋盘挪过来成这样的形状。我输入放在qipan[][]数组中,然后用一个临时数组temp[][]和棋盘大小一样,把这个临时数组全部初始化为0,走一步把这个数组更新为1(想象成马走日) 全部走到底,则遍历temp[][]数组,如果temp[][]不为0,即有走的,那么就输出棋盘上面对应的棋盘数字。分别用变量sum,和maxv来记录最大值,当为最大值时要保存走的状态,即输出走的最大值是哪步。最后我是用一个HashMap来保存所有的取值情况,在主函数中,如果hashmap的值 = maxv,则输出,最后得到结果。这种暴力解决方法是在数据量不多的情况下好解决,可是数据量多,就用动态规划来解决。
5.代码示例:
package com.zzl.zt;
/*
* 7
* 3 8
* 8 1 0
* 2 7 4 4
* 4 5 2 6 5
*/
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Scanner;
public class RouteTest {
static int qipan[][] = new int[20][20];
static int temp[][] = new int[20][20];
static int weizhi[][] = {{1,0},{1,1}}; // 只能向下走,或者向右下走
static int step = 1;
static int sum = 0;
static int maxv = 0;
static Map<StringBuffer, Integer> map = new HashMap<StringBuffer, Integer>();
public static void main(String[] args) {
Scanner scn = new Scanner(System.in);
System.out.println("请输入共有多少行并输入数据:");
int n = scn.nextInt(); //总共的行数
for(int i=0;i<n;i++){
for(int j=0;j<=i;j++){
qipan[i][j] = scn.nextInt();
temp[i][j] = 0;
}
}
temp[0][0] = step;
step++;
move(0,0,n); //把n行数传进去,要不然不知道行数
//遍历Map集合,一次输出,作为一个样本即可
Iterator it = map.entrySet().iterator();
while (it.hasNext()) {
Entry entry = (Entry) it.next();
if(entry.getValue() == Integer.valueOf(maxv)){
System.out.println(entry.getKey() + "最大值:" + entry.getValue());
}
}
}
public static void move(int x, int y, int n) {
int next_x = 0;
int next_y = 0;
if(step>n){ //递归到了底部
sum = 0;
StringBuffer sb = new StringBuffer();
sb.append("路径:");
for(int i=0;i<n;i++){
for(int j=0;j<=i;j++){
if(temp[i][j] !=0){ //也就是说有走过了
//这就是一个输出表示形式
if(i==n-1){
sb.append(qipan[i][j] + ",");
}else{
sb.append(qipan[i][j] + "-");
}
//计算这一趟sum的总值
sum = sum+qipan[i][j];
}
}
}
//判断sum是否更大,更大则更新数据
if(sum>maxv){
maxv = sum;
}
map.put(sb, sum);
}else{
for(int i=0;i<2;i++){ //只有两个位置可以走,并且这两个位置都能走,没有限制条件
next_x = x+weizhi[i][0];
next_y = y+weizhi[i][1];
temp[next_x][next_y] = step;
step++;
move(next_x, next_y, n);
temp[next_x][next_y] = 0;
step--;
}
}
}
}
java暴力递归回溯算法的更多相关文章
- Java数据结构之回溯算法的递归应用迷宫的路径问题
一.简介 回溯法的基本思想是:对一个包括有很多结点,每个结点有若干个搜索分支的问题,把原问题分解为对若干个子问题求解的算法.当搜索到某个结点.发现无法再继续搜索下去时,就让搜索过程回溯(即退回)到该结 ...
- 【C/C++】n皇后问题/全排列/递归/回溯/算法笔记4.3
按常规,先说一下我自己的理解. 递归中的return常用来作为递归终止的条件,但是对于返回数值的情况,要搞明白它是怎么返回的.递归的方式就是自己调用自己,而在有返回值的函数中,上一层的函数还没执行完就 ...
- java 二叉树递归遍历算法
//递归中序遍历 public void inorder() { System.out.print("binaryTree递归中序遍历:"); inorderTraverseRec ...
- [leetcode] 37. 解数独(Java)(dfs,递归,回溯)
37. 解数独 1A 这个题其实15分钟左右就敲出来并且对了...但是由于我输错了一个数..导致我白白debug一个多小时.. 没啥难度,练递归-dfs的好题 class Solution { pri ...
- java实现回溯算法
最近有在leetcode上面做算法题,已经遇到了两道回溯算法的题目,感觉一点思路都没有,现决定将java如何实现回溯算法做一次总结. 什么叫做回溯算法 (摘抄于百度百科) 回溯算法实际上一个类似枚举的 ...
- 回溯算法之n皇后问题
今天在看深度优先算法的时候,联想到DFS本质不就是一个递归回溯算法问题,只不过它是应用在图论上的.OK,写下这篇博文也是为了回顾一下回溯算法设计吧. 学习回溯算法问题,最为经典的问题我想应该就是八皇后 ...
- 8皇后以及N皇后算法探究,回溯算法的JAVA实现,非递归,循环控制及其优化
上两篇博客 8皇后以及N皇后算法探究,回溯算法的JAVA实现,递归方案 8皇后以及N皇后算法探究,回溯算法的JAVA实现,非递归,数据结构“栈”实现 研究了递归方法实现回溯,解决N皇后问题,下面我们来 ...
- 8皇后以及N皇后算法探究,回溯算法的JAVA实现,递归方案
八皇后问题,是一个古老而著名的问题,是回溯算法的典型案例.该问题是国际西洋棋棋手马克斯·贝瑟尔于1848年提出:在8×8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行.同 ...
- 剑指Offer——回溯算法解迷宫问题(java版)
剑指Offer--回溯算法解迷宫问题(java版) 以一个M×N的长方阵表示迷宫,0和1分别表示迷宫中的通路和障碍.设计程序,对任意设定的迷宫,求出从入口到出口的所有通路. 下面我们来详细讲一 ...
随机推荐
- 整理一点与排列组合有关的问题[组合数 Stirling数 Catalan数]
都是数学题 思维最重要,什么什么数都没用,DP直接乱搞(雾.. 参考LH课件,以及资料:http://daybreakcx.is-programmer.com/posts/17315.html 做到有 ...
- SPOJ 1812 LCS2 [后缀自动机 DP]
题意: 求多个串<=10的最长连续子串 一个串建SAM,然后其他串在上面走 每个状态记录所有串在这个状态的公共子串的最小值 一个串在上面走的时候记录与每个状态公共子串的最大值,注意出现次数向父亲 ...
- 第一周 动态规划Dynamic Programming(一)
一.概念 动态规划是运筹学的一个分支,是求解决策过程最优化的数学方法.动态规划是通过拆分问题,定义问题状态和状态之间的关系,使得问题能够以递推(或者说分治)的方式去解决. 1.试用情况: 2.解决步骤 ...
- u-boot核心初始化
异常向量表:异常:因为内部或者外部的一些事件,导致处理器停下正在处理的工作,转而去处理这些发生的事件.ARM Architecture Reference Manual p54页.7种异常的类型:Re ...
- ACE_TEST1.obj : error LNK2019: 无法解析的外部符号
ACE_TEST1.obj : error LNK2019: 无法解析的外部符号 "int __cdecl ace_main_i(int,char * * const)" (?ac ...
- 基于Java的WebSocket推送
WebSocket的主动推送 关于消息推送,现在的解决方案如轮询.长连接或者短连接,当然还有其他的一些技术框架,有的是客户端直接去服务端拿数据. 其实推送推送主要讲的是一个推的概念,WebSocket ...
- openvpn服务器一键脚本生成客户端文件
#!/bin/bash #获取参数 while getopts "n:" opt; do case $opt in n) client_name=$OPTARG ;; \?) ;; ...
- 开源项目-网上公开http代理爬取、简单分类
爬取网上公开免费代理(http/socks),解析入库,可满足需要切换IP的场景(爬虫.投票等)需求. 项目地址: https://github.com/Jwnie/proxyservice 1.采用 ...
- Linux 每日命令行
uptime 用于查看系统的负载信息. 它依次显示 当前系统时间.系统已运行时间.启用终端数量及平均负载值等信息.平均负载指的是系统在最近1分钟.5分钟.15分钟内的压力情况:负载值越低越好,尽量不要 ...
- Navi.Soft31.产品.微信聊天(永久免费)
1系统简介 1.1功能简述 微信确实是一款优秀的社交的软件,被越来越多的人使用.它的电脑版最新版本是2.6,更新也比较及时,只是它有一个功能差强人意,就是同一台电脑只能运行一个微信号,不知道为何这样设 ...