Chinaunix首页 | 论坛 | 博客
  • 博客访问: 242846
  • 博文数量: 59
  • 博客积分: 4010
  • 博客等级: 上校
  • 技术积分: 900
  • 用 户 组: 普通用户
  • 注册时间: 2009-03-30 20:21
文章分类

全部博文(59)

文章存档

2011年(1)

2009年(58)

我的朋友

分类: C/C++

2009-04-10 19:46:45

本程序主要是将一个数组中的元素进行全排列。其递归定义如下:
当n=1时,Perm(R) = (r),其中r是集合R中惟一的元素。
当n>1时,Perm(R)由(r1)Perm(R1)...(rn)Perm(Rn)构成。



#include

#define LEN 4

/* output the array */
void pfarr( const int arr[], const int len )
{
  int i = 0;
  for (i=0; i    {
      printf( "%d ", arr[i] );
    }
  printf( "\n" );
}

void swap( int arr[], int i, int j )
{
  int temp = arr[i];
  arr[i] = arr[j];
  arr[j] = temp;
}


void Perm( int arr[], const int len, int index )
{
  int i = 0;
 
  if (index == len)
    {
      pfarr( arr, len );
    }
  else
    {
      for (i=index; i    {
      swap( arr, i, index );
      Perm( arr, len, index+1 );
      swap( arr, i, index );
    }
     
    }
}

int main(int argc, char * argv[])
{
  int arr[LEN];
  int i = 0;
  for (i=0; i    {
      arr[i] = i+1;
    }
 
  Perm( arr, LEN, 0 );

  return 0;
}
阅读(705) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~