【算法】求{1,2,3}序列的全排列,邻里交换法(Java)

【算法】求{1,2,3}序列的全排列,邻里交换法(Java)
代码如下:

java 复制代码
public class Main{
    static int count;
    static int a[]= {1,2,3};
	public static void main(String[] args) {
        f(a,0);
        System.out.println(count);
	}
    public static void f(int a[],int step) {
    	if(step==a.length-1) {
    		count++;
    		return;
    	}
    	for(int i=step;i<a.length;i++) {
    		{
    			int x=a[i];//交换
    			a[i]=a[step];
    			a[step]=x;
    		}
    		f(a,step+1);
    		{
    			int x=a[i];//还原数据
    			a[i]=a[step];
    			a[step]=x;
    		}
    	}
    }
}

图解如下:

**执行过程如下:**这段代码实现了对数组 a 中元素的全排列,并在 count 中记录排列的数量。下面是每一步的具体细节:

  1. 初始状态:

    • a[] = {1, 2, 3}
    • count = 0
  2. 调用 f(a, 0),进入函数 f

    • a[] = {1, 2, 3}
    • step = 0
  3. 进入 for 循环,i = 0

    • 交换 a[0]a[0](实际上没有变化)
    • 进入递归,调用 f(a, 1)
      • a[] = {1, 2, 3}
      • step = 1
  4. 进入 for 循环,i = 1

    • 交换 a[1]a[1](实际上没有变化)
    • 进入递归,调用 f(a, 2)
      • a[] = {1, 2, 3}
      • step = 2
  5. step == a.length - 1 成立,执行 count++

    • count = 1
  6. 返回上一层递归,恢复数组 a 到初始状态:

    • a[] = {1, 2, 3}
  7. 继续 for 循环,i = 2

    • 交换 a[2]a[1],得到 a[] = {1, 3, 2}
    • 进入递归,调用 f(a, 2)
      • a[] = {1, 3, 2}
      • step = 2
  8. step == a.length - 1 成立,执行 count++

    • count = 2
  9. 返回上一层递归,恢复数组 a 到初始状态:

    • a[] = {1, 2, 3}
  10. 返回上一层递归,恢复数组 a 到初始状态:

    • a[] = {1, 2, 3}
  11. 继续 for 循环,i = 1

    • 交换 a[1]a[0],得到 a[] = {2, 1, 3}
    • 进入递归,调用 f(a, 1)
      • a[] = {2, 1, 3}
      • step = 1
  12. 进入 for 循环,i = 1

    • 交换 a[1]a[1](实际上没有变化)
    • 进入递归,调用 f(a, 2)
      • a[] = {2, 1, 3}
      • step = 2
  13. step == a.length - 1 成立,执行 count++

    • count = 3
  14. 返回上一层递归,恢复数组 a 到初始状态:

    • a[] = {2, 1, 3}
  15. 继续 for 循环,i = 2

    • 交换 a[2]a[1],得到 a[] = {2, 3, 1}
    • 进入递归,调用 f(a, 2)
      • a[] = {2, 3, 1}
      • step = 2
  16. step == a.length - 1 成立,执行 count++

    • count = 4
  17. 返回上一层递归,恢复数组 a 到初始状态:

    • a[] = {2, 1, 3}
  18. 返回上一层递归,恢复数组 a 到初始状态:

    • a[] = {1, 2, 3}
  19. 继续 for 循环,i = 2

    • 交换 a[2]a[0],得到 a[] = {3, 2, 1}
    • 进入递归,调用 f(a, 1)
      • a[] = {3, 2, 1}
      • step = 1
  20. 进入 for 循环,i = 1

    • 交换 a[1]a[1](实际上没有变化)
    • 进入递归,调用 f(a, 2)
      • a[] = {3, 2, 1}
      • step = 2
  21. step == a.length - 1 成立,执行 count++

    • count = 5
  22. 返回上一层递归,恢复数组 a 到初始状态:

    • a[] = {3, 2, 1}
  23. 继续 for 循环,i = 2

    • 交换 a[2]a[1](实际上没有变化)
    • 进入递归,调用 f(a, 2)
      • a[] = {3, 2, 1}
      • step = 2
  24. step == a.length - 1 成立,执行 count++

    • count = 6
  25. 返回上一层递归,恢复数组 a 到初始状态:

    • a[] = {3, 2, 1}
  26. 返回上一层递归,恢复数组 a 到初始状态:

    • a[] = {1, 2, 3}
  27. 返回上一层递归,主函数结束。

最终输出 count 的值为 6,表示数组 [1, 2, 3]

相关推荐
喻米粒06228 分钟前
RabbitMQ消息相关
java·jvm·spring boot·spring·spring cloud·sentinel·java-rabbitmq
陈皮话梅糖@1 小时前
使用 Provider 和 GetX 实现 Flutter 局部刷新的几个示例
开发语言·javascript·flutter
简简单单做算法1 小时前
基于mediapipe深度学习和限定半径最近邻分类树算法的人体摔倒检测系统python源码
人工智能·python·深度学习·算法·分类·mediapipe·限定半径最近邻分类树
hvinsion2 小时前
基于PyQt5的自动化任务管理软件:高效、智能的任务调度与执行管理
开发语言·python·自动化·自动化任务管理
Tisfy2 小时前
LeetCode 2360.图中的最长环:一步一打卡(不撞南墙不回头) - 通过故事讲道理
算法·leetcode··题解
Aphelios3802 小时前
Java全栈面试宝典:线程机制与Spring IOC容器深度解析
java·开发语言·jvm·学习·rbac
LuckyAnJo2 小时前
Leetcode-100 链表常见操作
算法·leetcode·链表
qq_529835353 小时前
装饰器模式:如何用Java打扮一个对象?
java·开发语言·装饰器模式
日暮南城故里3 小时前
Java学习------源码解析之StringBuilder
java·开发语言·学习·源码
Vitalia3 小时前
从零开始学Rust:枚举(enum)与模式匹配核心机制
开发语言·后端·rust