c语言从键盘输入一个字符串,用冒泡法对该字符串中的字符由大到小进行排序,并输出结果。
时间: 2023-06-26 17:08:03 浏览: 106
以下是使用冒泡排序法对输入的字符串进行字符由大到小排序的C语言程序:
```c
#include <stdio.h>
#include <string.h>
int main() {
char str[100];
int i, j, n;
printf("请输入一个字符串:");
gets(str);
n = strlen(str);
// 冒泡排序法
for (i = 0; i < n - 1; i++) {
for (j = 0; j < n - i - 1; j++) {
if (str[j] < str[j + 1]) {
// 交换相邻两个字符
char temp = str[j];
str[j] = str[j + 1];
str[j + 1] = temp;
}
}
}
printf("排序后的字符串为:%s\n", str);
return 0;
}
```
运行程序后,输入一个字符串,程序会对其中的字符进行排序,并输出结果。注意,该程序中使用了C标准库函数`gets()`,该函数不安全,容易受到缓冲区溢出等攻击,应该尽量避免使用。在实际开发中,可以使用更加安全的函数`fgets()`代替`gets()`。
相关问题
c语言 从键盘输入一个字符串,用冒泡法对该字符串中的字符由大到小进行排序,并输出结果。
好的,下面是C语言代码实现:
```c
#include <stdio.h>
#include <string.h>
void bubbleSort(char *str, int len) {
int i, j;
char temp;
for(i = 0; i < len; i++) {
for(j = 0; j < len - i - 1; j++) {
if(str[j] < str[j+1]) {
temp = str[j];
str[j] = str[j+1];
str[j+1] = temp;
}
}
}
}
int main() {
char str[100];
printf("请输入一个字符串:");
scanf("%s", str);
int len = strlen(str);
bubbleSort(str, len);
printf("排序后的字符串为: %s", str);
return 0;
}
```
以上代码实现了冒泡排序算法对输入的字符串进行排序,思路是每次从前往后依次比较相邻的两个字符,如果前面的字符比后面的字符小,则交换位置。经过多次比较和交换,最终可以得到由大到小排序的字符串。
C语言从键盘输入一个字符串,用冒泡法对该字符串中的字符由大到小进行排序,并输出结果。
以下是基于冒泡排序的 C 语言程序:
```c
#include <stdio.h>
#include <string.h>
void bubble_sort(char str[], int len) {
for (int i = 0; i < len - 1; i++) {
for (int j = 0; j < len - 1 - i; j++) {
if (str[j] < str[j + 1]) {
char temp = str[j];
str[j] = str[j + 1];
str[j + 1] = temp;
}
}
}
}
int main() {
char str[100];
printf("Enter a string: ");
fgets(str, sizeof(str), stdin);
int len = strlen(str) - 1; // fgets 会读入换行符,需要减去
bubble_sort(str, len);
printf("Sorted string: %s\n", str);
return 0;
}
```
该程序首先从键盘读入一个字符串,然后调用 `bubble_sort` 函数进行排序,最后输出排序后的字符串。其中,`bubble_sort` 函数实现了冒泡排序算法,通过比较相邻字符的大小,将较大的字符往前移动,从而实现排序。