在主函数中输入十个等长的字符串用另一函数对它们排序然后在主函数输出这十个已经排好序的字符串用指针的方法
时间: 2024-03-22 09:42:44 浏览: 61
C语言程序设计-将主函数中输入的字符串反序存放;例如:输入字符串“abcdefg”,则应输出“gfedcba”;.c
5星 · 资源好评率100%
以下是用指针的方法实现字符串排序的代码:
```c++
#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 = 10;
const int len = 50;
char strings[n][len];
for (int i = 0; i < n; i++) {
cin.getline(strings[i], len);
}
char *ptrs[n];
for (int i = 0; i < n; i++) {
ptrs[i] = strings[i];
}
sort_strings(ptrs, n);
cout << "Sorted strings:" << endl;
for (int i = 0; i < n; i++) {
cout << ptrs[i] << endl;
}
return 0;
}
```
代码中首先在主函数中定义了一个二维字符数组 `strings`,大小为 10 行 50 列,用于存储输入的字符串。然后使用循环调用 `cin.getline` 函数从标准输入读入这 10 个字符串。
接下来,定义一个指针数组 `ptrs`,用于存储 `strings` 数组中每个字符串的地址。循环遍历 `strings` 数组,将每个字符串的地址存储到 `ptrs` 数组中。
然后调用 `sort_strings` 函数,对 `ptrs` 数组中的指针进行排序。排序使用了冒泡排序算法,每次比较相邻两个字符串,如果前一个字符串大于后一个字符串,则交换它们在 `ptrs` 数组中的位置。
最后,在主函数中输出排序后的字符串,遍历 `ptrs` 数组,依次输出其中的字符串。
阅读全文