我试图测试我自己并想编写合并排序,而不是实际在网上查找任何代码,并在特定时间段内完成。我被困在这一点上,我不能简单地理解我做错了什么,因为据我所知,合并排序是将字符串划分到字符串只有 1 个字符的点,然后将它们重新合并在一起。我在下面编写的代码试图做同样的事情。我想知道我的概念是错误的,还是只是我的实现?
string merge(string str1, string str2) {
string final = "";
int i = 0, j = 0;
bool fromStr1 = false;
while(true) {
if(str1[i] < str2[j]) {
final += str1[i];
i++;
if(i == str1.size()) {
break;
}
}
else {
final += str2[j];
j++;
if(j == str2.size()) {
break;
fromStr1 = true;
}
}
}
if(fromStr1) {
for(int t = i; t < str1.size(); t++) {
final += str1[t];
}
}
else {
for(int t = j; t < str2.size(); t++) {
final += str2[t];
}
}
return final;
}
string mergeSort(string str1, int start, int end) {
if(end - start == 1)
return str1;
else {
int pivot = (end - start) / 2;
string newStr1 = mergeSort(str1, start, pivot);
string newStr2 = mergeSort(str1, pivot + 1, end);
return merge(newStr1, newStr2);
}
}