(力扣164)C语言-基数排序 最大间距

2024-09-03 09:04

本文主要是介绍(力扣164)C语言-基数排序 最大间距,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 题目
  • 解题思路
  • 代码

题目来源 力扣164
代码是官方题解,这篇文章是对官方题解的一个理解,记录学习日常哒,如若有错,欢迎指出吖~谢谢。

题目

给定一个无序的数组 nums,返回 数组在排序之后,相邻元素之间最大的差值 。如果数组元素个数小于 2,则返回 0 。

您必须编写一个在「线性时间」内运行并使用「线性额外空间」的算法。

示例 1:

输入: nums = [3,6,9,1]
输出: 3
解释: 排序后的数组是 [1,3,6,9], 其中相邻元素 (3,6) 和 (6,9) 之间都存在最大差值 3。
示例 2:

输入: nums = [10]
输出: 0
解释: 数组元素个数小于 2,因此返回 0。

提示:

1 <= nums.length <= 105
0 <= nums[i] <= 109

解题思路

基数排序的主要思想
遍历数组元素,按每个数组元素的各位、十位、百位等进行分配,再按序收集。

分配不难,主要是如何收集,其实我一开始接触到基数排序是在数据结构中,当时用的是链表,不过没有具体代码,只是简单了解一下思想,本题是具体实现,但是用的是数组。
收集的时候有个注意事项:用数组收集是我们是反向遍历数据的,但用链表实现时,正向遍历数组。
因为收集是按照先进先出(队列)的原则的,数组正向遍历是后进先出(栈),所以我们要反向遍历数组进行收集。

思路大致如下。我会在左边写出数组的分配形式,右边配有链表的思路,便于大家理解。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

代码注释也写了一些我做题时的想法

代码

int maximumGap(int* nums, int numsSize) {if (numsSize == 1) {return 0;}int exp = 1;//个位,十位,百位…int buf[numsSize];memset(buf, 0, sizeof(buf));int maxVal = INT_MIN;for (int i = 0; i < numsSize; i++) {maxVal = fmax(maxVal, nums[i]);//找最大值干嘛呢?//为了确定我们要进行几次分配收集}while (maxVal >= exp) {int cnt[10];//0-9,余数memset(cnt, 0, sizeof(cnt));for (int i = 0; i < numsSize; i++) {int digit = (nums[i] / exp) % 10;cnt[digit]++;//统计余数为i的有多少个元素}for (int i = 1; i < 10; i++) {cnt[i] += cnt[i - 1];//这一步是干嘛?//好像大概懂了,统计到i为止共有多少个元素,方便后面的排序}for (int i = numsSize - 1; i >= 0; i--) {int digit = (nums[i] / exp) % 10;buf[cnt[digit] - 1] = nums[i];//收集cnt[digit]--;}memcpy(nums, buf, sizeof(int) * numsSize);//在排序了exp *= 10;}int ret = 0;for (int i = 1; i < numsSize; i++) {ret = fmax(ret, nums[i] - nums[i - 1]);}return ret;
}

2024.9.3

这篇关于(力扣164)C语言-基数排序 最大间距的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1132583

相关文章

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

Go语言利用泛型封装常见的Map操作

《Go语言利用泛型封装常见的Map操作》Go语言在1.18版本中引入了泛型,这是Go语言发展的一个重要里程碑,它极大地增强了语言的表达能力和灵活性,本文将通过泛型实现封装常见的Map操作,感... 目录什么是泛型泛型解决了什么问题Go泛型基于泛型的常见Map操作代码合集总结什么是泛型泛型是一种编程范式,允

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

Go语言使用Buffer实现高性能处理字节和字符

《Go语言使用Buffer实现高性能处理字节和字符》在Go中,bytes.Buffer是一个非常高效的类型,用于处理字节数据的读写操作,本文将详细介绍一下如何使用Buffer实现高性能处理字节和... 目录1. bytes.Buffer 的基本用法1.1. 创建和初始化 Buffer1.2. 使用 Writ