枚举排列

生成1~n的排列
我们尝试用递归的思想解决:先输出以1开头的排列(这一步是递归调用),然后输出以2开头的排列(又是递归调用),接着是以3为开头的排列.....最后才是以n开头的排列。
以1开头的排列的特点是:第一位是1,后面是2~9的排列。根据字典序的定义,这些2~9的排列也必须按照字典序排列。换句话说,需要“按照字典序输出2~9的排列”,不过需要注意的是,在输出时,每个排列的最前面要加上“1”。这样一来,所设计的递归伪码如下:
void print_permutation(序列A,集合S){
if(S为空) 输出序列A;
else 按照从小到大的顺序依次考虑S的每个元素V{
print_permutation(在A末尾填加V后得到的新序列,S-{V});}
}
下面考虑程序实现。不难想到用数组表示序列A,而集合S根本不用保存。因为,它可以由序列A完全确定——A中没有出现的元素都可以选。同时,我们还需要一个参数记录当前需要确定的位置cur,代码如下:

创新互联是一家专注于成都网站建设、网站制作与策划设计,青秀网站建设哪家好?创新互联做网站,专注于网站建设十载,网设计领域的专业建站公司;建站业务涵盖:青秀等地区。青秀做网站价格咨询:18980820575


#include"stdio.h"
#include"stdlib.h"
void print_permutation(int *A,int n,int cur){
    if(cur==n){
        for(int i=0;i

文章名称:枚举排列
本文链接:http://bzwzjz.com/article/jegohi.html
Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 网站制作 响应式网站设计 成都网站制作公司 响应式网站设计 宜宾网站设计 成都网站制作 定制网站制作 四川成都网站制作 成都网站建设 高端网站设计 温江网站设计 网站设计制作报价 成都网站设计 商城网站建设 网站建设改版 教育网站设计方案 成都网站设计 手机网站制作设计 企业网站设计 定制网站建设多少钱 成都网站建设公司 网站设计