我有这个代码来生成字典排列。使用以下逻辑:
- 从给定测试字符串中字符的递增顺序排列开始。
- 要生成下一个字典排列:
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"
,那么我会遇到分段错误。请帮忙!!