c语言怎样将字符串存入指针属猪,字符数组全排列 - Lu堅的个人空间 - OSCHINA - 中文开源技术交流社区...

// win32Console.cpp : 定义控制台应用程序的入口点。

//

#include "stdafx.h"

#include

//参数为引用,函数调用多,所以定义我内联函数

inline void charSwap(char &_left, char &_right)

{// 交换_left和_right

char temp = _left;

_left = _right;

_right = temp;

}

//arr为字符数组,nPrefix表示前缀的下标,nSize表示arr大小(字符个数)

void fullPermulation(char arr[], int nPrefix, int nSize)

{//打印arr[]的全排列

int i=0;

if(nPrefix == nSize-1)

{//前缀是最后的位置,打印一个排列

for(i=0; i

putchar(arr[i]);

putchar('\n');

}

else

{//arr[nPrefix...nSize-1]有多种排列方式,递归地产生这些排列方式

for(i=nPrefix; i

{

if(i != nPrefix)

charSwap(arr[nPrefix], arr[i]);//交换前缀,产生下一次前缀

fullPermulation(arr, nPrefix+1, nSize);

if(i != nPrefix)

charSwap(arr[nPrefix], arr[i]);//恢复原有的顺序

}

}

}

int _tmain(int argc, _TCHAR* argv[])

{

char arr[]={'1', '2', '3'};

fullPermulation(arr, 0, sizeof(arr)/sizeof(char));

return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值