字符串排序

问题概要

给定 n 个字符串,请对 n 个字符串按照字典序排列

对应牛客网HJ14 字符串排序

思路分析

该问题思路相对来说比较简单:

  1. 使用数组接收用户输入的字符串
  2. 使用qsort方法对数组进行排序
  3. 输出排序后的数组

代码实现

c 复制代码
#include <stdio.h>
#include <string.h>
#include <stdlib.h>

#define MAX_STRING_LENGTH 101 // 字符串最大长度 

// 字符串比较函数
int string_compare(const void *a, const void *b) {
	return strcmp(*(const char **)a, *(const char **)b);
} 

int main() {
	int num = 0, i;
	scanf("%d", &num);
	
	// 动态分配一个字符串指针数组
	char **strings = (char **)malloc(num * sizeof(char *));
	for (i = 0; i < num; i++) {
		strings[i] = (char *)malloc(MAX_STRING_LENGTH * sizeof(char));
		scanf("%s", strings[i]);
	}
	
	// 使用qsort进行排序
	qsort(strings, num, sizeof(char *), string_compare);
	
	// 打印排序后的字符串
	for (i = 0; i < num; i++) {
		printf("%s\n", strings[i]);
		free(strings[i]);// 释放每个字符串的内存 
	}
	free(strings); // 释放字符串数组的内存 
	
	return 0;
}

因为该问题相对来说比较简单,所以也不在此过多赘述了,希望这篇文章,能起到些微参考作用。

感谢阅读,也祝大家开心!

相关推荐
背心2块钱包邮几秒前
第9节——部分分式积分(Partial Fraction Decomposition)
人工智能·python·算法·机器学习·matplotlib
仰泳的熊猫2 分钟前
1148 Werewolf - Simple Version
数据结构·c++·算法·pat考试
chao1898442 分钟前
MATLAB中的多重网格算法与计算流体动力学
开发语言·算法·matlab
大工mike3 分钟前
代码随想录算法训练营第四十四天 | 99.岛屿数量 深搜 99.岛屿数量 广搜 100. 岛屿的最大面积
算法
不穿格子的程序员18 分钟前
从零开始学算法——链表篇3:合并两个有序链表 + 两数相加
数据结构·算法·链表·dummy
暴风鱼划水38 分钟前
算法题(Python)哈希表 | 2.两个数组的交集
python·算法·哈希表
fufu031142 分钟前
Linux环境下的C语言编程(四十二)
linux·c语言·算法
HalvmånEver1 小时前
Linux : 基础IO(三)
linux·运维·算法
oushaojun21 小时前
linux中backtrace实战
linux·运维·算法·backtrace
埃伊蟹黄面1 小时前
模拟算法思想
c++·算法·leetcode