定义指针数组,使其指向字符串常量:char * name[4]={“Follow”,,“Great”, “FORTRAN”,“Computer”},并进行排序。实际是对指针指向的排序,字符串不动! 要求:函数调用实现。 定义指针数组,使其指向字符串常量:char * name[4]={“Follow”,,“Great”, “FORTRAN”,“Computer”},并进行排序。实际是对指针指向的排序,字符串不动! 要求:函数调用实现。
时间: 2023-09-18 19:11:20 浏览: 42
好的,这是一个经典的指针数组排序问题。可以使用冒泡排序或者快速排序来实现。这里我给出一个冒泡排序的示例代码:
```c
#include <stdio.h>
#include <string.h>
void sort(char *arr[], int n) {
int i, j;
char *temp;
for (i = 0; i < n - 1; i++) {
for (j = 0; j < n - i - 1; j++) {
if (strcmp(arr[j], arr[j+1]) > 0) {
temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
int main() {
char *name[4] = {"Follow", "Great", "FORTRAN", "Computer"};
int i;
sort(name, 4);
for (i = 0; i < 4; i++) {
printf("%s\n", name[i]);
}
return 0;
}
```
在这个示例代码中,我们定义了一个 `sort` 函数来对指针数组进行排序。排序采用的是冒泡排序,每次比较相邻的两个字符串指针,如果前面的大于后面的就将它们交换。最终得到的结果是指针数组中的指针按照字典序排列。最后在 `main` 函数中调用 `sort` 函数,并遍历输出排好序的指针数组中的字符串常量。