生成字符串的递归函数不包含两个相邻的相同子串c ++

时间:2015-04-05 10:10:40

标签: c++ string function recursion substring

我的任务很难处理。任务是:创建递归函数,该函数可以生成长度为N(N <= 100)的字符串,由字母“A”,“B”和“C”形成,并且不包含两个相同的相邻子字符串。例如:输入N = 6并且程序应该生成这样一个字符串,其中没有其他人重复子字符串:ABACAB。错误的字符串是: AA BACA - 因为'A'是'A'; BCBC A - 因为'BC'是'BC'而 ABCABC 也是错误的,因为'ABC'是'ABC'。

我制作了一个程序版本,但是采用了迭代方式,这里是代码:

#include <iostream>
#include <ctime>

using namespace std;

const char letters[] = "ABC";

char generate_rand()
{

     return letters[rand() % 3];

}

int check(char *s, int pos) 
{

    for (int i = 1; i <= (pos + 1)/2; i++) 
    {

        int flag = 1;

        for (int j = 0; j < i; j++)

        if (s[pos-j] != s[pos-i-j]) 
        {

            flag = 0; 
                break;

        }

        if (flag)
            return 1;

    }
    return 0;
}

int main() 
{

    char s[100];
    int n;

    cout << "enter n: ";
    cin >> n;

    srand(time(NULL));

    for (int i = 0; i < n; i++) 
    {

        do
        {

            s[i] = generate_rand();

        } while (check(s, i));

        cout << s[i] << " ";

    }

    cout << " ok" << endl;

    system("pause");
    return 0;
}

我认为递归函数的入口可能需要是字符串中的字符数,它将寻求与相邻字符串重复,每次增加1,但不超过原始字符串长度的一半,但不知道该怎么做。

1 个答案:

答案 0 :(得分:0)

所以让我们从一个简单的递归函数开始,它打印10个字母,但不检查任何东西:

void addLetter(char* buf, int max_length)
{
   int len = strlen(buf);
   buf[len] = generate_rand();
   if (strlen(buf) < max_length) 
      addLetter(buf);
}

int main()
{
   srand(time(NULL)); //I forgot srand!
   int max_length = 10; //ask user to input max_length, like you had earlier
   char buf[100];
   memset(buf,0,sizeof(buf));
   addLetter(buf, max_length);
   printf("\n%s\n", buf);
   return 0;
}

现在让我们改变递归函数,让它只检查1个字母:

void addLetter(char* buf, int max_length)
{
   int len = strlen(buf);
   buf[len] = generate_rand();

   if (len > 0)
   {
      if (buf[len] == buf[len-1])
         buf[len] = 0;
   }

   if (strlen(buf) < max_length) 
      addLetter(buf);
}

下一步,检查2个字母与之前的字母等。您应该可以从这里拿走它。