输出数组的全排列

思想:

  • n 个元素数组全排列 = 第 1 个前缀 + 后 n - 1 个元素全排列
  • 输出第 k 个元素之后的全排列:
    • 首先输出以 k 为前缀, 后 n - k 个元素的全排列
    • 然后依次将第 k 个元素与其后的元素互换,再进行后 n - k 个元素的全排列
    • 每一次互换 -> 排列之后,要互换恢复数组,以便于 k 与其后其他元素互换
  • 用递归实现,递归到最后一个数时候输出整个数组
#include <iostream>
using namespace std;

void perm(int list[], int k, int m)
{
    if (k == m) //递归到最后一个数,输出list
    {
        for (int i = 0; i < m; i++) {
            cout<<list[i]<<" ";
        }
        cout<<endl;
        return;
    }
    for (int i = k; i < m; i++) //第一次自己和自己换
    {
        swap(list[k], list[i]);
        perm(list, k + 1, m);
        swap(list[k], list[i]); //还原数组
    }
}

int main()
{
    int list[] = {1,2,3,4,5,6} ;
    perm(list, 0, sizeof(list) / sizeof(int));
    return 0;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1 序 2016年6月25日夜,帝都,天下着大雨,拖着行李箱和同学在校门口照了最后一张合照,搬离寝室打车去了提前租...
    RichardJieChen阅读 5,148评论 0 12
  • LeetCode 刷题随手记 - 第一部分 前 256 题(非会员),仅算法题,的吐槽 https://leetc...
    蕾娜漢默阅读 17,909评论 2 36
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,768评论 0 33
  • 数组在程序设计中,为了处理方便, 把具有相同类型的若干变量按有序的形式组织起来。这些按序排列的同类数据元素的集合称...
    朱森阅读 3,997评论 2 13
  • 从和高磊鑫复合起,薛之谦在热搜上躺了大半个月,却没想到过程是这样的曲折。从开始感人至深的爱情到撕落一地的鸡毛。 李...
    诸葛瑾瑾阅读 520评论 0 0