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

相关推荐
阿里嘎多学长1 小时前
2026-04-30 GitHub 热点项目精选
开发语言·程序员·github·代码托管
abcnull3 小时前
用javaparser做精准测试
java·ast·静态代码分析·精准测试·javaparser
叶小鸡3 小时前
Java 篇-项目实战-苍穹外卖-笔记汇总
java·开发语言·笔记
AI人工智能+电脑小能手3 小时前
【大白话说Java面试题】【Java基础篇】第22题:HashMap 和 HashSet 有哪些区别
java·开发语言·哈希算法·散列表·hash
昵称小白3 小时前
复杂度分析方法
算法
juniperhan3 小时前
Flink 系列第21篇:Flink SQL 函数与 UDF 全解读:类型推导、开发要点与 Module 扩展
java·大数据·数据仓库·分布式·sql·flink
科研前沿3 小时前
2026 数字孪生前沿科技:全景迭代报告 —— 镜像视界生成式孪生(Generative DT)技术白皮书
大数据·人工智能·科技·算法·音视频·空间计算
ID_180079054733 小时前
Python 实现亚马逊商品详情 API 数据准确性校验(极简可用 + JSON 参考)
java·python·json
c++之路4 小时前
C++23概述
java·c++·c++23
时空系4 小时前
第10篇:继承扩展——面向对象编程进阶 python中文编程
开发语言·python·ai编程