ali内推——继续理解DFS与回溯

题目

如图,某物流派送员p,需要给a、b、c、d4个快递点派送包裹,请问派送员需要选择什么的路线,才能完成最短路程的派送。假设如图派送员的起点坐标(0,0),派送路线只能沿着图中的方格边行驶,每个小格都是正方形,且边长为1,如p到d的距离就是4。随机输入n个派送点坐标,求输出最短派送路线值(从起点开始完成n个点派送并回到起始点的距离)。
输入
4
2,2
2,8
4,4
7,2
输出30
输入
2,2
2,8
6,6
输出28

ali内推——继续理解DFS与回溯_第1张图片

分析

  • 首先一定需要一个点集(Point[ ])
  • 其次,注意本题中需要最终回到原点,否则直接使用贪心算法每次走最短即可。所以,想到一个比较朴素的方法DFS回溯。
  • 具体过程,有疑惑的时候就debug一遍关注每一个细节,递归就不迷糊了。

MyCode

代码写的十分粗糙,毫不精致,希望以后功力深厚了,可以写出更好看的代码。注意注释笔记,fangbiangerenlijie

import java.util.Scanner;

/**
 * DFS,BFS,包括其他递归方法,保证其完整正确性首先要具有递归出口;
 * 其次,要考虑递归过程中是否携带 “状态记录”,若携带应注意记录的维护(自主维护还是递归栈“自己维护”)。
 * 由此引出一个,编程中的高效思想,即尽可能地不要直接使用形参。提倡方法内将参数进行拷贝,如此有利于
 * 状态与递归层次的对应关系(eg:下面代码中count+1优于count++,后者在回溯时需要--count);
 * 当然,这不是一个“死规矩”,一些全局状态就需要我们在回溯的时候小心维护————恢复现场。其实操作系统本身
 * 也是如此工作的,保留现场出现在指令中断、函数调用等多种场合。
 */

class Point{
    int px;
    int py;
    boolean visited;

    public Point(int px, int py) {
        this.px = px;
        this.py = py;
        this.visited = false;
    }

    public int getLength(Point p){
        return Math.abs(px - p.px) + Math.abs(py - p.py);
    }
}

public class AliKuaiDi {
    static final Point START = new Point(0,0);
    static int minpath = Integer.MAX_VALUE;

    public static int calculate(Point start, Point[] points, int sum, int count){
        if(count == points.length){
            minpath = Math.min(minpath, sum +start.getLength(START));
            return minpath;
        }
        for(int i = 0; iif(points[i].visited == false){
                sum += points[i].getLength(start);
                if(sum < minpath){
                    points[i].visited = true;
                    calculate(points[i], points, sum, count+1);
                }
                sum -= points[i].getLength(start);
                points[i].visited = false;
            }
        }
        return minpath;
    }

    public static void main(String[] args){
        Scanner input = new Scanner(System.in);
        int pnum = Integer.parseInt(input.nextLine().trim());
        /**构建点集*/
        Point[] points = new Point[pnum];
        for(int i = 0; i",");
            points[i] = new Point(Integer.parseInt(locations[0]), Integer.parseInt(locations[1]));
        }
        int min = calculate(START, points, 0, 0);
        System.out.println(min);
    }
}

你可能感兴趣的:(刷题笔记)