#include <iostream>
#include <string>
using namespace std;
void printinter(string p1, string p2, int m, int n, string output, int i);
int main (void)
{
string s1,s2,output="";
cin>>s1>>s2;
int m = s1.length();
int n = s2.length();
int i = 0;
printinter(s1,s2,m,n,output,1);
return 0;
}
void printinter(string p1, string p2, int m, int n, string output, int i)
{
if (m == 0 && n == 0)
{
cout<<output<<"\n";
return;
}
else if (m!= 0)
{
//string foo = p1.substr(0,1);
//cout<<foo<<"\t"; // used for debugging
output = output + p1.substr(0,1);
cout<<output<<"\t"; // used for debugging
printinter(p1.substr(i,m),p2,m-1,n,output,i+1);
}
else if (n != 0)
{
output = output + p2.substr(0,1);
printinter(p1,p2.substr(i,n),m,n-1,output,i+1);
}
}
上述代码基本上用于打印两个字符串s1
和s2
的所有交错。现在,我最初输入s1
和s2
,并将它传递给函数printinter
,它通过递归打印交织。基本上,它修复第一个字符,然后递归剩余的字符,然后修复其他字符串的第一个字符并递归剩余的字符,每次递减1个单位。最后,它打印输出。为什么发生这个错误?
当我尝试运行它,它给出了错误,libc++abi.dylib: terminating with uncaught exception of type std::out_of_range: basic_string Abort trap: 6
现在,我通过放置在不同的地方cout
语句来找出错误,因为在过去两年的时间想。但似乎没有任何工作。在运行调试器时,它不会在第一次迭代本身中打印output
。我不知道为什么。我不会在这里问它,但是,我不知道错误是什么。我通常自己调试代码,但是帮助我完成这个。谢谢!
它有太多的错误,为一个简单的答案。最严重的是,你不会在递归调用中交换字符串,所以它不会按照你想要的方式交替。但是因为它没有交替,所以当我通过在第一个字符串中的使用增加i时,将i用作第二个字符串的索引变得错误。 – JSF
我建议你简化并且只传递没有索引的子串或传递未修改的原始字符串以及索引。通过嵌套到递归调用中修改字符串和索引,您所做的事似乎是两次完成相同的工作,而您似乎混淆了您的意图。 – JSF