字符串的组合

简介: 题目:输入一个字符串,输出该字符串中字符的所有组合。举个例子,如果输入abc,它的组合有a、b、c、ab、ac、bc、abc。 此题也可以变换为字符串的排列。 假设我们想在长度为n的字符串中求m个字符的组合。

 题目:输入一个字符串,输出该字符串中字符的所有组合。举个例子,如果输入abc,它的组合有abcabacbcabc

此题也可以变换为字符串的排列

假设我们想在长度为n的字符串中求m个字符的组合。我们先从头扫描字符串的第一个字符。

针对第一个字符,我们有两种选择:

  1. 一是把这个字符放到组合中去,接下来我们需要在剩下的n-1个字符中选取m-1个字符;
  2. 二是不把这个字符放到组合中去,接下来我们需要在剩下的n-1个字符中选择m个字符。

这两种选择都很容易用递归实现。下面是这种思路的参考代码:

void Combination(char* string)
{
    if(string == NULL)
        return;

    int length = strlen(string);
    vector<char> result;
    for(int i = 1; i <= length; ++ i)
    {
        Combination(string, i, result);
    }
}

void Combination(char* string, int number, vector<char>& result)
{
    if(number == 0)
    {
        vector<char>::iterator iter = result.begin();
        for(; iter < result.end(); ++ iter)
            printf("%c", *iter);
        printf("\n");

        return;
    }

    if(*string == '\0')
        return;

    result.push_back(*string);
    Combination(string + 1, number - 1, result);
    result.pop_back();

    Combination(string + 1, number, result);
}

      由于组合可以是1个字符的组合,2个字符的字符……一直到n个字符的组合,因此在函数void Combination(char* string),我们需要一个for循环。另外,我们一个vector来存放选择放进组合里的字符。

来源:http://zhedahht.blog.163.com/blog/static/2541117420114172812217/

 

img_e00999465d1c2c1b02df587a3ec9c13d.jpg
微信公众号: 猿人谷
如果您认为阅读这篇博客让您有些收获,不妨点击一下右下角的【推荐】
如果您希望与我交流互动,欢迎关注微信公众号
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。

目录
相关文章
|
2月前
|
JavaScript 前端开发 Java
|
1月前
|
C++ 安全
高效遍历:C++中分隔字符串单词的3种方法详解与实例
拷贝并交换(Copy-and-Swap)是C++中实现赋值操作符和异常安全拷贝构造函数的技巧。它涉及创建临时对象,使用拷贝构造函数,然后交换数据以确保安全。C++11之前的策略在此后及C++11引入的移动语义和右值引用下仍有效,但后者提供了更高效的实现方式。
|
2月前
|
存储 索引
DAY-2 | 哈希思想:求字符串包含的字符集合
这是一个关于代码实现的问题,主要展示了两种利用哈希思想去除字符串中重复字符的方法。第一种方法使用了`boolean[] flg`数组来标记字符是否出现过,遍历字符串时,如果字符未出现则添加到结果并标记为已出现。第二种方法使用`char[] ch`数组直接存储字符出现状态,先遍历一次字符串记录出现过的字符,再遍历一次输出未标记的字符。
20 0
|
2月前
数字组合 (计蒜客 - T1218)
数字组合 (计蒜客 - T1218)
|
2月前
字符串,每个里面包含0-N个数字,如3,8,2,编写函数,将两个这样的字符串合并,并且输出的字符串里面没有重复的数字,并从大到小排列.
字符串,每个里面包含0-N个数字,如3,8,2,编写函数,将两个这样的字符串合并,并且输出的字符串里面没有重复的数字,并从大到小排列.
24 0
|
11月前
|
存储 索引
数组与字符串的关系【了解一下】
数组与字符串的关系【了解一下】
103 0
|
12月前
1291:数字组合
1291:数字组合
|
机器学习/深度学习 数据处理 索引
函数组合
函数组合
120 0
|
Python
计算两个字符串相(或句子)似度的方法
主要方法有:编辑距离、余弦相似度、模糊相似度百分比
129 0
计算两个字符串相(或句子)似度的方法
|
自然语言处理 搜索推荐 索引
组合数据类型
组合数据类型
169 0
组合数据类型