首页 > 编程语言 >Java回溯知识点(含面试大厂题和源码)

Java回溯知识点(含面试大厂题和源码)

时间:2024-03-23 09:32:02浏览次数:27  
标签:知识点 Java nums int 选择 算法 源码 回溯 tempList

回溯算法是一种通过遍历所有可能的候选解来寻找所有解的算法,如果候选解被确认不是一个解(或至少不是最后一个解),回溯算法会通过在上一步进行一些变化来丢弃这个解,即“回溯”并尝试另一个候选解。回溯法通常用递归方法来实现,在解决排列、组合、选择问题时非常有效。

回溯算法的核心要点:

  1. 路径:也就是已经做出的选择。
  2. 选择列表:也就是你当前可以做的选择。
  3. 结束条件:也就是到达决策树底层,无法再做出选择的条件。

回溯算法的框架:

回溯算法的基本形式大致如下:

void backtrack(路径, 选择列表) {
    if (满足结束条件) {
        result.add(路径);
        return;
    }

    for (选择 : 选择列表) {
        做选择;
        backtrack(路径, 选择列表);
        撤销选择;
    }
}

回溯算法的关键点:

  • 递归前做选择:将当前节点加入路径中,同时将其从选择列表移除。
  • 递归:递归前的选择导向下一层决策树。
  • 递归后撤销选择:将之前做的选择撤销,以回溯至上一步,从而尝试下一个选项。

回溯算法的应用场景:

  • 排列问题:要求输出一个集合的所有排列方式,比如全排列问题。
  • 组合问题:要求输出满足条件的所有组合方式,比如组合总和问题。
  • 选择问题:从集合中选出满足条件的所有子集,比如子集问题、分割问题。

优化技巧:

  • 剪枝:在遍历过程中,对于明显不会得到正确解的情况直接跳过,减少不必要的计算。
  • 使用合适的数据结构:比如使用数组、链表或是集合等,根据问题场景选用最适合的数据结构,以便于添加、删除操作,优化时间复杂度。

回溯算法通过尝试分步的方式去解决一个问题,在分步解决问题的过程中,当它通过尝试发现现有的分步答案不能得到有效的正确的解答时,它将取消上一步甚至是上几步的计算,再通过其他的可能的分步解答再次尝试寻找问题的答案。回溯法非常适合用来解决由多个步骤组成的问题,每个步骤有多个选项,通过尝试每个选项并回退到上一个步骤,最终找到解决问题的方法。在软件开发面试中,经常会遇到需要编写源码来解决问题的算法题。这里我将为你提供三道面试中常见的算法题及其Java实现,这些题目不仅考察基本编程能力,还考察对特定算法和数据结构的理解和应用。

1. 全排列

题目描述:给定一个没有重复数字的序列,返回其所有可能的全排列。

示例

输入: [1,2,3]
输出:
[
  [1,2,3],
  [1,3,2],
  [2,1,3],
  [2,3,1],
  [3,1,2],
  [3,2,1]
]

Java解法

public List<List<Integer>> permute(int[] nums) {
    List<List<Integer>> list = new ArrayList<>();
    backtrack(list, new ArrayList<>(), nums);
    return list;
}

private void backtrack(List<List<Integer>> list, List<Integer> tempList, int [] nums){
    if(tempList.size() == nums.length){
        list.add(new ArrayList<>(tempList));
    } else{
        for(int i = 0; i < nums.length; i++){
            if(tempList.contains(nums[i])) continue; // element already exists, skip
            tempList.add(nums[i]);
            backtrack(list, tempList, nums);
            tempList.remove(tempList.size() - 1);
        }
    }
}

2. 合并K个排序链表

题目描述:合并 k 个排序链表,返回合并后的排序链表。

示例

输入:
[
  1->4->5,
  1->3->4,
  2->6
]
输出: 1->1->2->3->4->4->5->6

Java解法

public ListNode mergeKLists(ListNode[] lists) {
    if(lists.length == 0) return null;
    PriorityQueue<ListNode> queue = new PriorityQueue<>(lists.length, Comparator.comparingInt(a -> a.val));
    ListNode dummy = new ListNode(0);
    ListNode tail = dummy;
    for(ListNode node : lists)
        if(node != null)
            queue.add(node);
    while(!queue.isEmpty()){
        tail.next = queue.poll();
        tail = tail.next;
        if(tail.next != null)
            queue.add(tail.next);
    }
    return dummy.next;
}

3. 最长连续序列

题目描述:给定一个未排序的整数数组,找出最长连续序列的长度。

示例

输入: [100, 4, 200, 1, 3, 2]
输出: 4
解释: 最长连续序列是 [1, 2, 3, 4]。长度为 4。

Java解法

public int longestConsecutive(int[] nums) {
    Set<Integer> numSet = new HashSet<>();
    for (int num : nums) {
        numSet.add(num);
    }
    int longestStreak = 0;
    for (int num : numSet) {
        if (!numSet.contains(num - 1)) {
            int currentNum = num;
            int currentStreak = 1;
            while (numSet.contains(currentNum + 1)) {
                currentNum += 1;
                currentStreak += 1;
            }
            longestStreak = Math.max(longestStreak, currentStreak);
        }
    }
    return longestStreak;
}

这三道题目分别覆盖了回溯算法、优先队列和哈希表的使用,是面试中常见的算法题类型。理解这些解法的关键思想和代码实现,对准备软件开发面试大有帮助。

标签:知识点,Java,nums,int,选择,算法,源码,回溯,tempList
From: https://blog.csdn.net/2302_80314137/article/details/136958713

相关文章

  • Java的编码、消息摘要、数字签名、加密(推荐)
    Java中,编码和加密是两个不同的概率,分别作用于不同的目标。我们在日常开发中偶尔也会用到关于这两个东西,比如对数据加密,账号密码进行加密等情况,下面我围绕Java的编码和加密进行相关介绍和讲解。Java编码编码作为Java中将数据转换为另一种格式的过程,通常是用于数据的传输和......
  • Java之类和对象(精简版-更适合复习)
    什么是类?描述一个对象的。什么是对象?真正的一个实体。类和对象就是为了进行面向对象编程。//定义类classStudent//类名大驼峰{}每一个类都可以有main方法类如何产生对象呢?通过new关键字实例化对象。可以实例化多个对象,但不能有无限个,因为堆有大小,内存有限。......
  • django《大学计算机》课程思政资源共享平台(源码+mysql+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取本课题的源码和程序系统程序文件列表系统的选题背景和意义选题背景:在当今信息化社会,教育领域正逐渐实现数字化转型,其中课程资源的共享与利用成为提高教学效率和质量的关键。特别是对于《大学计算机》这类基础且重要的课程,构......
  • django+Mybatis的医生在线诊所平台(源码+mysql+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取本课题的源码和程序系统程序文件列表系统的选题背景和意义选题背景:随着互联网技术的迅猛发展和普及,越来越多的传统行业开始向数字化转型。医疗健康领域作为与人们生活密切相关的行业,其服务模式也正逐渐从传统的面对面诊疗转......
  • djangoJAVA汽车年审管理系统(源码+mysql+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取本课题的源码和程序系统程序文件列表系统的选题背景和意义选题背景:随着汽车产业的快速发展,汽车已经成为人们日常生活中不可或缺的交通工具。然而,随着汽车数量的增加,汽车安全问题也日益凸显。为了确保道路交通安全,各国政府都......
  • 【附源码】django计算机毕业设计web的房屋租赁系统的设计与实现(源码+mysql+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取本课题的源码和程序系统程序文件列表系统的选题背景和意义选题背景:随着经济的发展和社会的进步,人们对于居住环境的需求越来越高。房屋租赁市场作为房地产市场的重要组成部分,近年来呈现出快速发展的态势。然而,传统的房屋租赁......
  • 【故障诊断】基于卷积神经网络结合长短时记忆CNN-LSTM实现数据分类含Matlab源码
     ✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,代码获取、论文复现及科研仿真合作可私信。......
  • 【机器学习】详细解析Sklearn中的StandardScaler---原理、应用、源码与注意事项
    【机器学习】详细解析Sklearn中的StandardScaler—原理、应用、源码与注意事项......
  • java方法详解
    java方法详解方法是语句的集合。目的是解决一类问题。一个方法只完成一个功能,这样有利于后期的扩展。(单一职责原理)java都是值传递!有一个值copy的过程。publicclassDemo02{publicstaticvoidmain(String[]args){intmax=max(10,20);System.......
  • Java-Java基础学习(5)-注解和反射以及类的加载过程分析
    4.1注解的理解Annotation是从JDK5.0开始引入的新技术Annotation的作用不是程序本身,可以对程序作出解释(这点和注释comment没什么区别);可以被其他程序(比如:编译器等)读取;Annotation的格式注解是以“@注释名”在代码中存在的,还可以添加一些参数值,例如:@SuppressWarnings(v......