2

我有这个代码来生成字典排列。使用以下逻辑:

  1. 从给定测试字符串中字符的递增顺序排列开始。
  2. 要生成下一个字典排列:

a) 找到比下一个字符小的最右边的字符。说 A。

b) 在 A 的右边,找到下一个较大的字符。说 B. 并交换 A 和 B。

c) 在 A 原位置的右边,按升序对字符进行排序。

当我们得到最后一个排列时,算法结束。即给定测试字符串的反转。我的测试字符串s = "0123456789"

编辑: 在程序的每次运行中,我都会得到一个单独的分段错误位置。

得到一个:

int firstchar(string s){
int pos = s.length()-2;
for(int i=pos;i>=0;i--){
    if(s[i]<s[i+1]){
        pos = i;
        break;
    }
}
return pos;}

得到 B 然后递归方法(qsort 是一个函数<cstdlib>):

int ceilchar(string s, int fc){
int ceil = fc+1;
int diff=27;
for(int i=ceil;i<s.length();i++){
    if(s[i]>s[fc] && s[i]-s[fc]<diff){
        ceil = i;
        diff  = s[i]-s[fc];
    }
}
return ceil;}

启动功能:

void nextpermute(string& s){
int fc = firstchar(s);
int cc = ceilchar(s,fc);
swap(s,fc,cc);
sort(&s[fc]+1,&s[fc]+s.length()-fc);
if(s!="9876543210"){
    cout<<s<<"\n";
    nextpermute(s);
}
else
    cout<<s<<"\n";}

从主调用:nextpermute(test);

如果测试字符串是"01234567"或小于这个,它工作得很好。但如果它是类似 "012345678"or的字符串"0123456789",那么我会遇到分段错误。请帮忙!!

4

1 回答 1

1

我怀疑你的筹码量超过了它的极限。如果您在 Linux 上运行它,请执行“限制”并查看您的堆栈大小。有两种方法可以避免这种情况

1)(不推荐)做“限制堆栈大小无限制”(仅当您使用基于 unix 的系统时)。并再次运行该程序。

2)(推荐)。

改变

void nextpermute(string& s){
    int fc = firstchar(s);
    int cc = ceilchar(s,fc);
    swap(s,fc,cc);
    sort(&s[fc]+1,&s[fc]+s.length()-fc);
    if(s!="9876543210"){
        cout<<s<<"\n";
        nextpermute(s);
    }
    else
        cout<<s<<"\n";
}

void nextpermute(string& s){
    int fc = firstchar(s);
    int cc = ceilchar(s,fc);
    swap(s,fc,cc);
    sort(&s[fc]+1,&s[fc]+s.length()-fc);
    cout <<s<<"\n";
}

并将您的主要功能修改为

int main()
{
    string s = "0123456789";
    while (s != "9876543210")
    {
        nextpermute(s);
    }
}

上述更改将消除“nextpermute”的递归,因此您的堆栈大小限制将永远不会被跨越

于 2013-08-11T12:26:09.687 回答