【算法】求{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]

相关推荐
один but you4 分钟前
从可变参数到 emplace:现代 C++ 性能优化的核心组合
java·开发语言
是码龙不是码农30 分钟前
ThreadPoolExecutor 7 个核心参数详解
java·线程池·threadpool
这是程序猿1 小时前
Spring Boot自动配置详解
java·大数据·前端
MY_TEUCK1 小时前
【Java 后端 | Nacos 注册中心】微服务治理原理、选型与注册发现实战
java·开发语言·微服务
测试员周周1 小时前
【Appium 系列】第13节-混合测试执行器 — API + UI 的协同执行
开发语言·人工智能·python·功能测试·ui·appium·pytest
m0_629494731 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户2 小时前
用队列实现栈
数据结构·算法
光泽雨2 小时前
c#中的Type类型
开发语言·前端
做人求其滴2 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
见叶之秋2 小时前
C++基础入门指南
开发语言·c++