c++程序设计,输入5个字符串(含空格),用指针实现按字母顺序由小到大对字符串 排序后输出。
时间: 2024-02-09 17:12:07 浏览: 60
以下是一个使用指针实现字符串排序的示例代码:
```
#include <iostream>
#include <cstring>
using namespace std;
void sort_strings(char** strings, int n) {
for (int i = 0; i < n - 1; i++) {
for (int j = i + 1; j < n; j++) {
if (strcmp(strings[i], strings[j]) > 0) {
char* temp = strings[i];
strings[i] = strings[j];
strings[j] = temp;
}
}
}
}
int main() {
const int n = 5;
char* strings[n];
// 输入5个字符串
for (int i = 0; i < n; i++) {
string str;
getline(cin, str);
strings[i] = new char[str.length() + 1];
strcpy(strings[i], str.c_str());
}
// 对字符串排序
sort_strings(strings, n);
// 输出排序后的字符串
for (int i = 0; i < n; i++) {
cout << strings[i] << endl;
}
// 释放内存
for (int i = 0; i < n; i++) {
delete[] strings[i];
}
return 0;
}
```
在上面的代码中,我们定义了一个`sort_strings`函数,它使用了一个指向字符指针的指针作为参数。在函数内部,我们使用了两个嵌套的循环来比较字符串并进行排序。我们使用`strcmp`函数来比较两个字符串的大小,如果第一个字符串大于第二个字符串,则交换它们的位置。在`main`函数中,我们定义了一个指向字符指针的数组`strings`,并使用`getline`函数从输入流中读取5个字符串。我们使用`new`关键字为每个字符串分配内存,并使用`strcpy`函数将字符串复制到分配的内存中。然后,我们调用`sort_strings`函数对字符串进行排序,并输出排序后的字符串。最后,我们使用`delete`关键字释放每个字符串占用的内存。
阅读全文