当前位置: 首页 > news >正文

【LeetCode刷题集】--排序(一)

😘个人主页:@Cx330❀

👀个人简介:一个正在努力奋斗逆天改命的二本觉悟生

📖个人专栏:《C语言》《LeetCode刷题集》《数据结构-初阶》

前言:这是主播的第一篇LeetCode刷题集,这篇博客以及后续的博客都会带着大家刷题,由于考虑到大家的算法能力,刚开始会带着大家刷简单题,后续会慢慢加大难度,尝试一些中等难度的题,希望大家可以坚持到底,我们共同进步! 


目录

题目一:多数元素

题意:

思路:

代码实现:

复杂度分析:

qsort函数

概念:

参数及其原理:

 cmp函数简单实现

题目二:存在重复元素

 题意:

思路:

代码实现: 

复杂度分析:

题目三:有效的字母异位词

题意:

 思路:

代码实现:

复杂度分析:


题目一:多数元素

题目链接: 169.多数元素-力扣(LeetCode)

题意:

题目中给了一个大小为n数组nums,要求要返回在数组中出现次数大于n/2的元素。

思路:

“同归于尽消杀法” :

由于多数超过50%, 比如100个数,那么多数至少51个,剩下少数是49个。

第一个到来的士兵,直接插上自己阵营的旗帜 flag = nums[i] 占领这块高地,现存兵力 flagnum= 1。

如果新来的士兵和前一个士兵是同一阵营,则集合起来占领高地,flag不变依然是当前这个士兵所属阵营,现存兵力 flagnum++;

如果新来到的士兵不是同一阵营,则当前 flag 阵营派一个士兵和它同归于尽。 此时flag阵营兵力flagnum--。(即使双方都死光,这块高地的旗帜 flag 依然不变,因为已经没有活着的士兵可以去换上自己的新旗帜)

当下一个士兵到来,发现 flag 阵营已经没有兵力,则直接插上自己阵营的旗帜 flag = nums[i] 占领这块高地,现存兵力 flagnum++。

就这样各路军阀一直以这种以一敌一同归于尽的方式厮杀下去,直到少数阵营都死光,那么最后剩下的几个必然属于多数阵营,flag 就是多数阵营。

代码实现:

int majorityElement(int* nums, int numsSize) 
{int flag=nums[0];int flagnum=0;int i=0;while(i<numsSize){//同一个阵营兵力++if(nums[i]==flag){flagnum++;i++;}//没有兵力else{if(flagnum==0){flag=nums[i];i++;flagnum++;}//不同阵营else{flagnum--;i++;}}}return flag;
}

复杂度分析:

  注:这里不讨论空间复杂度的情况了,通常情况下时间复杂度是影响通过的关键因素

时间复杂度:O(N)

如果大家对复杂度分析这块知识不是很清晰的话可以看一下我数据结构初阶的博客:



【数据结构初阶】--算法复杂度详解


qsort函数

概念:

qsort()函数是一个C语言编译器函数库自带的排序函数,它可以对指定数组(包括字符串,二维数组,结构体等)进行排序

参数及其原理:

从cplusplus官网(cplusplus(C语言函数查询网站))上我们可以看到qsort()函数有四个参数的,如图: 

而cplusplus官网对这四个变量的解释是:

  • void*base :qsort()函数需要的第一个参数是待排序数组的首元素地址,而void*的意思是它是一个无类型指针,而无类型的原因是我们希望它是一个可以排序很多种类数据的排序函数,如果这里的指针类型固定,我们就只能对函数传入固定类型的参数进行排序了。
  • size_t num:这个参数代表待排数组的元素个数。且因为元素个数恒为非负数,因此该参数的数据类型size_t(即无符号整形)。
  • size_t size:这个参数代表待排数组的元素个数。且因为元素个数恒为非负数,因此该参数的数据类型size_t(即无符号整形)。
  • compar:通常简写为cmp经过我们的分析可知,该参数是一个函数指针,该指针指向的函数需要两个无类型的指针作为参数,同时该函数的返回值是一个int类型的整形。他的作用是将传进来的两个参数进行比较,如果参数p1<参数p2,则返回一个小于0的数,如果参数p1=参数p2,则返回0;如果参数p1>p2,则返回一个大于0的数

 cmp函数简单实现

int cmp(const void* a, const void* b) {

    return *(int*)a -*(int*)b;

}

补充:*(int*)a -*(int*)b排序过后得到的是升序数组,若想要得到降序数组,把二者反过来即可:*(int*)b-*(int*)a


题目二:存在重复元素

题目链接: 217.存在重复元素-力扣(LeetCode)

 

 题意:

题目中给了一个整数数组nums,如果任一值在数组中出现最少两次,返回true,否则返回false

思路:

qsort排序: 

对原数组直接进行qsort排序,此时得到有序数组,判断数组相邻元素是否相等,如果相等则返回true,否则返回false

补充:qsort()函数是一个C语言编译器函数库自带的排序函数,它可以对指定数组(包括字符串,二维数组,结构体等)进行排序

代码实现: 

int cmp(const void* _a, const void* _b) {int a = *(int*)_a, b = *(int*)_b;return a - b;
}bool containsDuplicate(int* nums, int numsSize) {qsort(nums, numsSize, sizeof(int), cmp);for (int i = 0; i < numsSize - 1; i++) {if (nums[i] == nums[i + 1]) {return true;}}return false;
}

复杂度分析:

时间复杂度:O(NlogN)


题目三:有效的字母异位词

 题目链接:242.有效的字母异位词-力扣(LeetCode)

题意:

给定两个字符串s和t,判断是否为异位次

异位词:两个字符串的元素种类及个数都相同,顺序不同 

 思路:

 qsort排序s和t,strcmp比较s和t的字符种类以及个数即可。

如果大家对字符串函数(strcmp等)不太清楚的话可以看下我之前写的博客,帮助大家快速理解:

【C语言】:字符串函数超详解(10个最重要函数)

代码实现:

int cmp(const void*a,const void*b)
{return *(char*)a-*(char*)b;
}
bool isAnagram(char* s, char* t) 
{size_t ssize=strlen(s);size_t tsize=strlen(t);qsort(s,ssize,sizeof(char),cmp);qsort(t,tsize,sizeof(char),cmp);int flag=strcmp(s,t);if(flag==0){return true;}return false;
}

复杂度分析:

时间复杂度:O(NlogN)


总结:这篇博客给大家找了三个排序类的题目,题目难度都很简单,其中涉及了许多函数,大家可以通过查漏补缺来弥补自己不清楚或者是忘却的知识,这里把有关这篇博客的知识点总结了一下,大家可以通过回顾之前的博客来进行复习

【数据结构初阶】--算法复杂度详解

【C语言】:字符串函数超详解(10个最重要函数)

结语:最后希望大家可以每天练一道算法题,来帮助自己提高算法能力,算法不是一蹴而就,而是通过一朝一夕的坚持刷题而积累的!大家感兴趣的话可以先看一下往期回顾中的几篇文章,都是对于数据结构来说比较重要的一些C语言知识储备,如果文章对你有帮助的话,欢迎评论,点赞,收藏加关注,感谢大家的支持。🌹🌹🌹 

http://www.dtcms.com/a/314281.html

相关文章:

  • 深入解析SmolVLA:VLM与动作专家间的注意力机制交互
  • 嵌入式硬件中三极管原理分析与控制详解
  • sqli-libs通关教程(31-40)
  • Pytorch-速查表-常用层和模块以及使用方法
  • FPGA实现Aurora 8B10B数据回环传输,基于GTP高速收发器,提供6套工程源码和技术支持
  • 三防平板电脑是什么?这款三防平板支持红外测温!
  • Ribbon 核心原理与架构详解:服务负载均衡的隐形支柱
  • 生产环境中基于Istio的Kubernetes多集群灰度发布架构实战经验分享
  • Django 性能优化详解:从数据库到缓存,打造高效 Web 应用
  • JavaScript案例(待办事项列表)
  • vue--for循环中使用子组件,ref应该如果调用
  • SP30D120CTT大电流碳化硅二极管全面解析:TO-247封装的高功率解决方案
  • Minio部署和客户端使用 - 版本 2025-05-24T17-08-30Z
  • 计算机网络:网络号和网络地址的区别
  • [激光原理与应用-135]:光学器件 - 透镜的本质是利用材料对光的折射特性,通过特定形状的表面设计,实现对光线的会聚、发散或成像控制的光学元件
  • HTTP各个版本对比
  • 【YOLO11】【DeepSort】【NCNN】使用YOLOv11和DeepSort进行行人目标跟踪。(基于ncnn框架,c++实现)
  • 文件与目录操作命令
  • Kubernetes(k8s)之认识Pod
  • k8s简介
  • Go语言 并发安全sync
  • 深度解析:CPU 与 GPU 上的张量运算,为何“快”与“慢”并非绝对?
  • 亚马逊撤离Google购物广告:重构流量生态的战略博弈
  • 从零开始搞定类与对象(中)
  • 企业架构被大模型重构:大模型驱动下的数字基建革命与机遇
  • 操作系统:RPC 中可能遇到的问题(Issues in RPC)
  • Ubuntu系统VScode实现opencv(c++)图像一维直方图
  • Git如何同步本地与远程仓库并解决冲突
  • C#利用unity游戏引实现开发设备仿真系统步骤
  • 《解构Angular组件变化检测:从自动到手 动的效能突破》