首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >如何输出字符窜的所有组合

如何输出字符窜的所有组合

作者头像
用户1624346
发布2018-04-17 17:31:57
1.1K0
发布2018-04-17 17:31:57
举报
文章被收录于专栏:calmoundcalmound

例如“abc”输出a,b,c,ab,ac,bc,abc

#include<stdio.h>
void DFS(char str[],char ss[],int pos,int cnt,int n)
{
    if(n==pos)
    {
        ss[cnt]='\0';
        if(cnt!=0) printf("%s\n",ss);
        return ;
    }
    ss[cnt]=str[pos];
    DFS(str,ss,pos+1,cnt+1,n);
    DFS(str,ss,pos+1,cnt,n);
}

int main()
{
    char str[]="abc";
    char ss[10];
    DFS(str,ss,0,0,3);
    return 0;
}

非递归

#include<stdio.h>

int main()
{
    char str[]="abc";
    int n=3;
    char ss[10];
    for(int i=1;i<(2<<n-1);i++)
    {
        int t=i;
        int cnt=0;
        while(t)
        {
            int x=t&1;
            if(x) printf("%c",str[cnt]);
            t>>=1;
            cnt++;
        }
        printf("\n");
    }
    return 0;
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2014-08-30 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档