char型数组穷举4个元素的排列组合
- 你的回答被采纳后将获得:
- 系统奖励15(财富值+成长值)+难题奖励10(财富值+成长值)+提问者悬赏5(财富值+成长值)
展开全部
#include "stdafx.h"
#include "stdio.h"
#include "stdlib.h"
#include "memory.h"
void print_all_order(char order[], int length, char chs[], int cnt)
{
if(cnt == 0)
{
for(int idx=0; idx<length; idx++)
{
if(idx+1<length)
printf("%c,", order[idx]);
else
printf("%c\n", order[idx]);
}
}
else
{
char* buf = (char*)malloc(cnt-1);
for(int idx=0; idx<cnt; idx++)
{
order[length] = chs[idx];
int thx = 0 ;
for(int j=0; j<cnt; j++)
{
if(idx != j)
buf[thx++] = chs[j];
}
print_all_order(order, length+1, buf, cnt-1);
}
free(buf);
}
}
int main(int argc, char* argv[])
{
char order[4] = {0};
char chs[4] = {'A', 'B', 'C', 'D'};
print_all_order(order, 0, chs, 4);
getchar();
return 0 ;
}
#include "stdio.h"
#include "stdlib.h"
#include "memory.h"
void print_all_order(char order[], int length, char chs[], int cnt)
{
if(cnt == 0)
{
for(int idx=0; idx<length; idx++)
{
if(idx+1<length)
printf("%c,", order[idx]);
else
printf("%c\n", order[idx]);
}
}
else
{
char* buf = (char*)malloc(cnt-1);
for(int idx=0; idx<cnt; idx++)
{
order[length] = chs[idx];
int thx = 0 ;
for(int j=0; j<cnt; j++)
{
if(idx != j)
buf[thx++] = chs[j];
}
print_all_order(order, length+1, buf, cnt-1);
}
free(buf);
}
}
int main(int argc, char* argv[])
{
char order[4] = {0};
char chs[4] = {'A', 'B', 'C', 'D'};
print_all_order(order, 0, chs, 4);
getchar();
return 0 ;
}
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2014-11-26
展开全部
最简单的穷举,就是4个循环。。。。。。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询