【C语言】从键盘上输入5个字符串(约定:每个字符串中字符数≤80字节),对其进行升序排序并输出。

本文介绍如何使用C语言从键盘输入5个长度不超过80字节的字符串,并进行升序排序。通过实例讲解了C语言中的字符串操作和排序算法,重点在于指针的应用。
#include<stdio.h>
#include<string.h>

#define ROW 5
#define COL 80

void sortString01(char (*pName)[COL]);//直接将姓名二维数组交换顺序(冒泡)
void sortString02(char **ppnames);//使用指针数组存储姓名,将指针数组调换顺序(冒泡)

int main(void)
{
	int i;
	char names[ROW][COL];
	char *ppname[ROW];

	//键盘输入五个待排序名字
	printf("Please Input %d names:\n", ROW);
	for(i = 0 ; i < ROW ; i ++)
	{
		gets(names[i]); //scanf("%s", names[i]);
	}

	//使用指针数组储存姓名
	for(i = 0 ; i < ROW ; i ++)
	{
		ppname[i] = names[i];
	}

	//第一种排序
	sortString01(names);

	//打印结果
	printf("After 01 Names:\n");
	for(i = 0 ; i < ROW ; i ++)
	{
		puts(names[i]); //printf("%s\n", names[i]);
	}

	//第二种排序
	sortString02(ppname);

	//打印结果
	printf("After 02 Names:\n");
	for(i = 0 ; i < ROW ; i ++)
	{
		puts(ppname[i]); //printf("%s\n", names[i]);
	}

	return 0;
}


void sortString01(char (*pName)[COL])
{
	int i, j;
	char temp[COL];

	for(i = 1 ; i < ROW; i ++)
	{
		for(j = 0 ; j < ROW - i ; j ++)
		{
			if(strcmp(pName[j], pName[j + 1]) > 0 )//顺序排列
			{
				strcpy(temp, pName[j]);
				strcpy(pName[j], pName[j + 1]);
				strcpy(pName[j + 1], temp);
			}
		}
	}
}

void sortString02(char **ppnames)
{
	int i,j;
	char *temp = NULL;

	for(i = 1 ; i < ROW ; i ++)
	{
		for(j = 0 ; j < ROW -i ; j ++)
		{	
			if(strcmp(ppnames[j], ppnames[j + 1]) < 0)//倒序排列
			{
				temp = ppnames[j];
				ppnames[j] = ppnames[j + 1];
				ppnames[j + 1] = temp;
			}
		}
	}
}

在C语言中,你可以通过以下几个步骤来完成这个任务: 1. **输入阶段**: 使用`fgets()`函数从键盘用户输入的五个字符串每个最多80个字符。因为`fgets()`会在遇到换行符、EOF或达到指定长度(这里是81,加上终止符`\0`)时停止读,所以需要确保有足够的空间。 ```c char A[5][81]; // 为了容纳换行符,数组大小多出一个位置 for (int i = 0; i < 5; i++) { fgets(A[i], sizeof(A[i]), stdin); } ``` 2. **处理换行符**: `fgets()`会包含一个换行符,我们需要移除它。 ```c for (int i = 0; i < 5; i++) { A[i][strcspn(A[i], "\n")] = '\0'; // 移除换行符 } ``` 3. **字符串转成可比较的整型或字符数组**: 因为原始数据是字符串形式,这里我们将它们转换为可以比较的格式,例如使用`atoi()`或` strcmp()`。然后使用冒泡排序算法字符串进行升序排列。注意这里假设所有字符串都是数字的字符串表示。 ```c // 示例使用strcmp进行比较 bool compare(const char* a, const char* b) { return strcmp(a, b) < 0; } void bubbleSort(char A[][81], int n) { for (int i = 0; i < n - 1; i++) { for (int j = 0; j < n - 1 - i; j++) { if (compare(A[j], A[j + 1])) { // 交换字符串 char temp[81]; strcpy(temp, A[j]); strcpy(A[j], A[j+1]); strcpy(A[j+1], temp); } } } } // 调用排序函数 bubbleSort(A, 5); ``` 4. **输出阶段**: 排序完成后,只需遍历数组打印结果即可。 ```c for (int i = 0; i < 5; i++) { printf("%s\n", A[i]); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值