Chinaunix首页 | 论坛 | 博客
  • 博客访问: 200858
  • 博文数量: 67
  • 博客积分: 2970
  • 博客等级: 少校
  • 技术积分: 685
  • 用 户 组: 普通用户
  • 注册时间: 2010-07-23 11:36
文章分类

全部博文(67)

文章存档

2012年(2)

2011年(19)

2010年(46)

我的朋友

分类: C/C++

2010-07-23 13:51:19

可以套用全排列的方法来枚举一个问题的所有情况,然后筛选出满足要求的一组数据

 

#include<stdio.h>
#include<algorithm>
using std::swap;

const int N=3;
int s[N];

void dfs(int depth)
{
    if(depth==N)
    {
        for(int i=0;i<N;i++)
        {
            printf("%4d",s[i]);
        }
        printf("\n");
        return ;
    }

    for(int i=depth;i<N;i++)
    {
        swap(s[depth],s[i]);
        dfs(depth+1);
        swap(s[depth],s[i]);
    }
}

int main()
{
    for(int i=0;i<N;i++)
        s[i]=i;

    dfs(0);

    return 0;
}

 

全排列的数学证明:

令E={e1,e2,e3……en}表示n个元素的集合,Ei表示E中除去元素i后的集合,prem(X)表示集合X中所有元素的所有全排列方式

例如:n=3,E={a,b,c}

prem(E)=a*prem({b,c})+b*prem({a,c})+c*prem({a,b})=a*(b*prem({c})+c*prem({b}))+b*(a*prem({c})+c*prem({a}))+c*(a*prem({b})+b*prem({a}))=a*(bc,cb)+b*(ac,ca)+c*(ab,ba)=(abc,acb,bac,bca,cab,cba)

由于计算机内存是线性的,所以在编程处理E集合的元素序列中通过交换在序列中的第depth位置的元素来实现全排列,这也可以看成是一个深度优先搜索,在一个序列上从前往后依次搜索满足要求的元素                  

阅读(1000) | 评论(0) | 转发(0) |
0

上一篇:没有了

下一篇:八皇后问题

给主人留下些什么吧!~~