friend4343 2017-07-22 15:20 采纳率: 0%
浏览 952

截取字符串功能如何实现

请教一个问题:字符串abadcafg,我想取出里面所有的组合放到数组里,最小是两个,请问咋实现呢?结果就是:ab,aba,abad,abadc,abadca,abadcaf,abadcafg,ba,bad,badc,badca,badcaf,badcafg,以此类推

string[] txt = new string[100];
for(int i = 1; i < firstStr.Length; i++)
{
txt[i-1] = firstStr.Substring(0, i+1);
}
这是我的代码,但只能实现ab,aba,abad,abadc,abadca,abadcaf,abadcafg这些,后面的无法实现了。不知道怎么改

  • 写回答

3条回答 默认 最新

  • 1000001000,,,, 2017-07-23 01:17
    关注

    #include
    #include
    using namespace std;

    void Combination(char* string, int number, vector& result)

    {
    if(number == 0)
    {
    vector::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);
    

    }

    void combination(char* string)
    {
    if(string == NULL)
    return;
    int length = strlen(string);
    vector result;
    for(int i = 1; i <= length; ++ i)
    {
    Combination(string, i, result);
    }
    }

    int main()
    {
    char *str ="abcd";
    combination(str);
    getchar();
    return 0;
    }

    评论

报告相同问题?