字符串排序

问题概要

给定 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;
}

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

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

相关推荐
JianminZheng3 小时前
MTPA算法原理及仿真验证
算法
im_AMBER3 小时前
Leetcode 38
笔记·学习·算法·leetcode
Miraitowa_cheems4 小时前
LeetCode算法日记 - Day 82: 环形子数组的最大和
java·数据结构·算法·leetcode·决策树·线性回归·深度优先
Code_Shark4 小时前
AtCoder Beginner Contest 426 题解
数据结构·c++·算法·数学建模·青少年编程
仰泳的熊猫4 小时前
LeetCode:698. 划分为k个相等的子集
数据结构·c++·算法·leetcode
豐儀麟阁贵5 小时前
4.5数组排序算法
java·开发语言·数据结构·算法·排序算法
Jane-6667775 小时前
C语言——栈与队列
c语言·开发语言
Shinom1ya_5 小时前
算法 day 32
算法
richxu202510016 小时前
C语言<<超全.超重要>>知识点总结
c语言·开发语言
WBluuue6 小时前
数据结构与算法:摩尔投票算法
c++·算法·leetcode