在主函数中定义以下10个等长的字符串,用另一函数对它们排序,然后在主函数输出这10个已排好序的字符串:abc edf ghi jkl mno pwr stu vwx yz1 234
时间: 2024-01-21 22:18:20 浏览: 27
以下是一个用冒泡排序对字符串进行排序的示例代码:
```c++
#include <iostream>
#include <string>
using namespace std;
void bubbleSort(string arr[], int n) {
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - i - 1; j++) {
if (arr[j] > arr[j+1]) {
swap(arr[j], arr[j+1]);
}
}
}
}
int main() {
string arr[10] = {"abc", "edf", "ghi", "jkl", "mno", "pwr", "stu", "vwx", "yz1", "234"};
int n = sizeof(arr)/sizeof(arr[0]);
bubbleSort(arr, n);
for (int i = 0; i < n; i++) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}
```
输出结果为:
```
234 abc edf ghi jkl mno pwr stu vwx yz1
```
相关问题
用C语言在主函数中输入10个等长字符串,用另一个函数对它们排序,然后在主函数输出这10个已排好序的字符串。
好的,以下是使用 C 语言编写的程序,可以在主函数中输入 10 个等长的字符串,然后使用另一个函数将它们排序,并在主函数中输出排序后的字符串:
```c
#include <stdio.h>
#include <string.h>
void sort_strings(char str[][100], int n);
int main() {
char str[10][100];
int i;
printf("请输入 10 个等长的字符串:\n");
for (i = 0; i < 10; i++) {
printf("第 %d 个字符串:", i + 1);
fgets(str[i], 100, stdin);
str[i][strlen(str[i]) - 1] = '\0'; // 去掉换行符
}
sort_strings(str, 10);
printf("排序后的字符串为:\n");
for (i = 0; i < 10; i++) {
printf("%s\n", str[i]);
}
return 0;
}
void sort_strings(char str[][100], int n) {
int i, j;
char temp[100];
for (i = 0; i < n - 1; i++) {
for (j = i + 1; j < n; j++) {
if (strcmp(str[i], str[j]) > 0) {
strcpy(temp, str[i]);
strcpy(str[i], str[j]);
strcpy(str[j], temp);
}
}
}
}
```
在这个程序中,我们首先定义了一个二维字符数组 `str`,用于存储输入的 10 个字符串。然后,我们使用一个 `for` 循环来逐一输入这些字符串,注意使用 `fgets` 函数读取输入,并且去掉输入字符串中的换行符。
接下来,我们调用了一个名为 `sort_strings` 的函数,用于对输入的字符串进行排序。该函数接收两个参数,第一个参数是一个二维字符数组,表示需要排序的字符串集合;第二个参数是一个整数,表示字符串的个数。
在 `sort_strings` 函数中,我们使用两个嵌套的 `for` 循环来实现排序。在外层循环中,我们依次处理每一个字符串,然后在内层循环中,将当前字符串与后面的字符串逐一比较,如果当前字符串比后面的字符串大,则交换它们的位置。这样,经过几轮比较和交换后,字符串数组就被排好序了。
最后,在主函数中,我们输出排好序的字符串,注意在输出时每个字符串后面需要加上换行符。
在主函数中输入十个等长的字符串用另一函数对它们排序然后在主函数输出这十个已经排好序的字符串用指针的方法
以下是用指针的方法实现字符串排序的代码:
```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` 数组,依次输出其中的字符串。