Java中常用的递归算法
创始人
2024-11-15 03:32:44
0

Java中常用的递归算法

  • 一、前言
    • 1. 阶乘计算
    • 2. 斐波那契数列
    • 3. 二叉树遍历
    • 4. 汉诺塔问题
    • 5. 组合生成


一、前言

Java 中常用的递归算法涵盖了许多领域,从简单的数据结构操作到复杂的算法和问题求解。以下是一些常见的递归算法示例:

1. 阶乘计算

计算一个非负整数的阶乘。例如,n! = n * (n-1) * ... * 1

public int factorial(int n) {     if (n == 0 || n == 1) {         return 1;     } else {         return n * factorial(n - 1);     } } 

2. 斐波那契数列

返回第 n 个斐波那契数。斐波那契数列的定义是 fib(n) = fib(n-1) + fib(n-2),其中 fib(0) = 0fib(1) = 1

public int fibonacci(int n) {     if (n <= 1) {         return n;     } else {         return fibonacci(n - 1) + fibonacci(n - 2);     } } 

3. 二叉树遍历

二叉树的前序、中序和后序遍历都可以用递归实现。

// 二叉树节点定义 class TreeNode {     int val;     TreeNode left;     TreeNode right;     TreeNode(int x) { val = x; } }  // 前序遍历 public void preorderTraversal(TreeNode root) {     if (root != null) {         System.out.print(root.val + " ");         preorderTraversal(root.left);         preorderTraversal(root.right);     } }  // 中序遍历 public void inorderTraversal(TreeNode root) {     if (root != null) {         inorderTraversal(root.left);         System.out.print(root.val + " ");         inorderTraversal(root.right);     } }  // 后序遍历 public void postorderTraversal(TreeNode root) {     if (root != null) {         postorderTraversal(root.left);         postorderTraversal(root.right);         System.out.print(root.val + " ");     } } 

4. 汉诺塔问题

经典的递归问题,将 n 个盘子从一个柱子移动到另一个柱子,每次只能移动一个盘子,并且大盘子不能放在小盘子上面。

public void hanoi(int n, char from, char to, char aux) {     if (n == 1) {         System.out.println("Move disk 1 from " + from + " to " + to);     } else {         hanoi(n - 1, from, aux, to);         System.out.println("Move disk " + n + " from " + from + " to " + to);         hanoi(n - 1, aux, to, from);     } } 

5. 组合生成

生成长度为 k 的从 n 个元素中选取的所有组合。

public void combinations(List> result, List temp, int start, int n, int k) {     if (k == 0) {         result.add(new ArrayList<>(temp));         return;     }      for (int i = start; i <= n - k + 1; i++) {         temp.add(i);         combinations(result, temp, i + 1, n, k - 1);         temp.remove(temp.size() - 1);     } } 

这些例子展示了递归在不同问题中的应用,包括数学运算、数据结构遍历以及组合生成。在实际应用中,递归算法通常需要考虑性能、边界条件和栈溢出等问题。

相关内容

热门资讯

黑科技辅助!wpk辅助神器(透... 黑科技辅助!wpk辅助神器(透视)软件透明辅助挂(本来是真的有挂)-哔哩哔哩是一款可以让一直输的玩家...
5分钟了解“创思维正版辅助器下... 5分钟了解“创思维正版辅助器下载”详细透视开挂辅助安装-哔哩哔哩;一、创思维正版辅助器下载有挂的是的...
两分钟科普!wpk真吗,哈糖大... 两分钟科普!wpk真吗,哈糖大菠萝可以开挂吗,曝光教程(发现有挂)-哔哩哔哩哈糖大菠萝可以开挂吗辅助...
第一分钟了解(昆仑大厅)外挂辅... 第一分钟了解(昆仑大厅)外挂辅助插件(透视)详细教程(2022已更新)(哔哩哔哩);亲真的是有正版授...
黑科技辅助!wpk俱乐部长期盈... 黑科技辅助!wpk俱乐部长期盈利打法(透视)软件透明挂黑科技(切实存在有挂)-哔哩哔哩;1、让任何用...
第6分钟了解“功夫川嘛辅助器”... 第6分钟了解“功夫川嘛辅助器”详细透视开挂辅助器-哔哩哔哩;人气非常高,ai更新快且高清可以动的一个...
第五分钟辅助!xpoker辅助... 第五分钟辅助!xpoker辅助,德州透视插件,攻略教程(有挂方法)-哔哩哔哩德州透视插件辅助器中分为...
两分钟了解(皮皮跑胡子)外挂透... 两分钟了解(皮皮跑胡子)外挂透明挂辅助工具(辅助挂)透明挂教程(2020已更新)(哔哩哔哩);皮皮跑...
黑科技辅助!微扑克可以加入俱乐... 您好,微扑克可以加入俱乐部这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩...
8分钟了解“掌中乐游戏中心辅助... 8分钟了解“掌中乐游戏中心辅助器”详细透视开挂辅助脚本-哔哩哔哩;1、这是跨平台的掌中乐游戏中心辅助...