首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >打印C语言中字符串的所有排列

打印C语言中字符串的所有排列
EN

Stack Overflow用户
提问于 2013-06-08 01:22:02
回答 5查看 49.5K关注 0票数 18

我正在学习回溯和递归,并且我被一种打印字符串的所有排列的算法所困扰。我用置换的bell algorithm解决了这个问题,但是我不能理解递归方法。我在网上搜索了一下,发现了下面的代码:

代码语言:javascript
复制
void permute(char *a, int i, int n) 
{
   int j; 
   if (i == n)
     printf("%s\n", a);
   else
   {
        for (j = i; j <= n; j++)
       {
          swap((a+i), (a+j));
          permute(a, i+1, n);
          swap((a+i), (a+j)); 
       }
   }
} 

我不明白这个算法是怎么工作的?我甚至尝试过干式跑步!

回溯是如何应用的?

在计算排列时,它是否比Bell算法更有效?

EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16989689

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档