用c语言采用指针变量作为形参,编写一个实现两字符交换的函数。在主函数中输入一个字符串,调用字符交换函数将其中的字符按从小到大的顺序排序后输出。
时间: 2024-02-13 14:02:41 浏览: 127
好的,这是一个简单的C语言编程题目。下面是代码实现:
```c
#include <stdio.h>
void swap(char *a, char *b) {
char temp = *a;
*a = *b;
*b = temp;
}
void sort(char *str, int len) {
int i, j;
for (i = 0; i < len - 1; i++) {
for (j = i+1; j < len; j++) {
if (str[i] > str[j]) {
swap(&str[i], &str[j]);
}
}
}
}
int main() {
char str[100];
printf("请输入一个字符串: ");
scanf("%s", str);
int len = 0;
while (str[len] != '\0') {
len++;
}
sort(str, len);
printf("排序后的字符串为: %s\n", str);
return 0;
}
```
首先,我们定义了一个 `swap` 函数,它接受两个字符指针作为参数,用来交换两个字符的值。然后,我们定义了一个 `sort` 函数,它接受一个字符指针和字符串长度作为参数,用来将字符串中的字符按从小到大的顺序排序。在 `sort` 函数中,我们使用了两个循环来遍历字符串中的所有字符,如果前面的字符比后面的字符大,则调用 `swap` 函数交换它们的值。
在主函数中,我们先输入一个字符串,并计算出它的长度。然后,我们调用 `sort` 函数将字符串排序,并输出排序后的结果。
注意,在输入字符串时,我们使用了 `%s` 格式化字符串来接受字符串,这会自动将字符串的结束符 `\0` 加在字符串末尾。在计算字符串长度时,我们使用了一个循环来遍历字符串中的所有字符,直到遇到结束符为止。
阅读全文