本篇文章为笔者的LeetCode刷题笔记。文章整体分为两部分:1.笔者自己思考的算法及代码。2.LeetCode官方给出的最优算法及代码。通过对比这两部分算法和代码的异同,笔者的算法思想和编程水平有了显著地提升。如果这篇文章能帮到你那真是再好不过了!
一、笔者思考的算法
bool containsDuplicate(int* nums, int numsSize){
int cur;
for(int i=0;i
执行代码通过了,但超出了时间限制。
于是转换思路,算法:先对数组排序,然后再一次比较数组各项,若有重复返回true。(可采用时间复杂度为O(n^2), 空间复杂度为O(1)的冒泡排序,也可采用时间空间复杂度均为O(nlogn)的快速排序。
冒泡排序:
void bubble_sort(int* nums,int numsSize){
int m,i,j,x;
for(m=1;m<=numsSize-1;m++){
for(j=0;jnums[j+1]){
x=nums[j];
nums[j]=nums[j+1];
nums[j+1]=x;
}
}
}
}
bool containsDuplicate(int* nums, int numsSize){
bubble_sort(nums,numsSize);
for(int i=0;i
提示超出时间限制。
冒泡排序时间复杂度为O(n^2),空间复杂度为O(1)。那试试快速排序吧。
快速排序:
int Partition(int *nums, int low, int high){
int cur=nums[low];
int pivotkey=nums[low];
while(low=pivotkey){
high--;
}
nums[low++]=nums[high];
while(low
依然显示超出时间限制,晕。。 原来c语言的
二、官方答案
以下代码也是官方答案中的排序方法:
int compare(const void * a, const void *b){ //比较函数 const void *指的是指向无类型的指针
int num1 = *(int*)a; //将a指针强制转换为int型,再将其所指的整数复制给num1
int num2 = *(int*)b;
return num1-num2; //若从大到小排,则为 num2-num1
}
bool containsDuplicate(int* nums, int numsSize){
qsort(nums,numsSize,sizeof(int),compare); //qsort的四个参数分别为数组始址,元素个数,元素大小,以及比较函数名
for(int i=0;i
复杂度分析
时间复杂度:O(NlogN),其中 N 为数组的长度。需要对数组进行排序。
空间复杂度:O(logN),其中 N 为数组的长度。注意我们在这里应当考虑递归调用栈的深度。
三、笔者小结
可以不必手撕快速排序或冒泡排序代码,
关于qsort()函数用法:https://www.cnblogs.com/vito_wang/p/12499582.html
https://www.bilibili.com/video/BV1Nx411D7sU?from=search&seid=11982473592254318506
Keep calm and carry on!
谢谢你看到这里!