0


【LeedCode每周总结】还在犹豫怎么刷LeedCode有没有用?快来加入每日刷题卷进大厂吧,冲冲冲

🌟 前言

🌟 同学们,我是上火不找我😎

🌟 今天是LeedCode每日一练打卡的一周总结!

🌟 挑了一些很不错又很实用的基础题目,捎带着还有一些实用的算法,大家一起前来复习一下吧~~~

⭐️往期集锦⭐️ | LeedCode两周刷完数据结构 |
LeedCode121. 买卖股票的最佳时机(Java语言实现)LeedCode1.两数之和(Java语言实现)LeedCode73. 矩阵置零(Java语言实现)LeedCode217. 存在重复元素(Java语言实现LeedCode88. 合并两个有序数组(Java语言实现)LeedCode1492. n 的第 k 个因子(Java语言实现)LeedCode118. 杨辉三角(Java语言实现)——教你在两周时间刷完数据结构


提示:以下是本篇文章正文内容,下面案例可供参考

LeedCode两周刷完数据结构

🌟 一、169. 多数元素(Java语言实现)

题目描述

在这里插入图片描述

推荐方法:排序

思路和算法:
我们可以用Java自带的API对数组进行排序,然后出现次数大于N/2的元素自然就会在中间了(小细节:既然题目出现了N/2,肯定是个偶数项,会简单很多)。

public int majorityElement(int[] nums){
        Arrays.sort(nums);return nums[nums.length /2];}

🌟 二、912. 排序数组(Java语言实现)

题目描述:

在这里插入图片描述

推荐方法:排序

思路和算法:我本着试一试的态度,没想到能过,这里我用的是包装类,大家可以用八大排序的任意一种,过几天我会写一个八大排序的文章,大家记得来捧场哦

public boolean containsDuplicate(int[] nums){
        Arrays.sort(nums);for(int i =0; i < nums.length-1; i++){if(nums[i]==nums[i+1]){returntrue;}}returnfalse;}

🌟 三、164. 最大间距(Java语言实现)

题目描述:

在这里插入图片描述

推荐方法:使用包装类API

思路和算法:排序API的作用就是传入一一个数组,并且对数组按照给定的规则进行就地排序。
**不知道大家写完爱看官方解答还是评论呢,这题官方给的解答过太过麻烦了,我这里使用的是包装类别的

sort

方法还有

max

方法,这样的话问题转化为只需要线性查找然后求最大差值就可以了。**

public int maximumGap(int[] nums){
        Arrays.sort(nums);
        int max =0;for(int i =1; i < nums.length; i++){
            max = Math.max(max, nums[i]- nums[i -1]);}return max;}

🌟 四、905. 按奇偶排序数组(Java语言实现)

题目描述:

在这里插入图片描述

推荐方法:使用额外数组折半添加

思路和算法:
这道题由于没有要求对奇数和偶数在进行排序,所以简单很多,这样的话,我们额外建立一个数组,在这个新数组的两端进行添加(按照题目要求:把偶数放在前面,奇数放在后面),然后返回得到的新数组就可以了。

public int[]sortArrayByParity(int[] nums){
        int[] res =newint[nums.length];
        int i =0, j = nums.length -1;for(int n: nums){if(n %2==0){
                res[i++]= n;}else{
                res[j--]= n;}}return res;}

🌟 五、539. 最小时间差(Java语言实现)

题目描述:

在这里插入图片描述

推荐方法:化串为整,排序处理,循环相减

思路和算法:
这道题看起来很复杂,但是用到的知识还是简单易懂的,我们只需要理清时间的转化就会好很多,这样的话就好解决了。

  • (1)字符串中格式化对应的整数;
  • (2)讲小时和分钟转换成分钟;
  • (3)对分钟进行排序处理;
  • (4)取相邻时间的间隔最小者;
  • (5) 注意时间循环的情况;
public int findMinDifference(List<String> timePoints){if(timePoints.size()<2||timePoints.size()>1440){return0;}
        int time[]=newint[timePoints.size()];for(int i=0;i<timePoints.size();i++){time[i]=stringToTime(timePoints.get(i));}
        Arrays.sort(time);
        int ans=time[0]-time[time.length-1]+1440;for(int i=1;i<time.length;i++){ans=Math.min(ans,time[i]-time[i-1]);}return ans;}public int stringToTime(String s){//把时间的格式化表示转换为距离午夜的时间return Integer.parseInt(s.substring(0,2))*60+Integer.parseInt(s.substring(3));}

🌟 六、976. 三角形的最大周长(Java语言实现)

题目描述

在这里插入图片描述

推荐方法:排序(A+B>C)

思路和算法:
利用三角形两边之和大于第三边的性质,假设小的两条边为a和b,大的那条为c,那么必须满足如下等式才能满足它是一 个三角形。
这个问题要求最大的三角形周长,那么势必是最大的那条边c越大越好,所以我们可以枚举将所有的边按照递增排序,然后逆序枚举最大的那条边c,去剩下的边里找小的两条边,最好的情况肯定是比C小的最大和次大边最优,如果这两条边都不能满足上述不等式。
剩下的边也就肯定也不满足了,所以只需要一个循环即可 解决问题。

public int largestPerimeter(int[]A){
        Arrays.sort(A);for(int i =A.length -1; i >=2; i--){
            int a =A[i];
            int b =A[i -1];
            int c =A[i -2];if(a < b + c){return a + b + c;}}return0;}

🌟 七、881. 救生艇(Java语言实现)

题目描述:

在这里插入图片描述

推荐方法:贪心

思路和算法:
要使需要的船数尽可能地少,应当使载两人的船尽可能地多。
设 people 的长度为 n。考虑体重最轻的人:

  • 若他不能与体重最重的人同乘一艘船,那么体重最重的人无法与任何人同乘一艘船,此时应单独分配一艘船给体重最重的人。从 people 中去掉体重最重的人后,我们缩小了问题的规模,变成求解剩余 n-1个人所需的最小船数,将其加一即为原问题的答案。
  • 若他能与体重最重的人同乘一艘船,那么他能与其余任何人同乘一艘船,为了尽可能地利用船的承载重量,选择与体重最重的人同乘一艘船是最优的。从 people 中去掉体重最轻和体重最重的人后,我们缩小了问题的规模,变成求解剩余 n−2 个人所需的最小船数,将其加一即为原问题的答案。

在代码实现时,我们可以先对 people 排序,然后用两个指针分别指向体重最轻和体重最重的人,按照上述规则来移动指针,并统计答案。

public int numRescueBoats(int[] people, int limit){
        Arrays.sort(people);
        int n = people.length;//  (1)按照重量从小到大排序;
        int i =0, j = n -1;while(i < j){if(people[j]+ people[i]<= limit){//(2)如果只剩一个人,那么直接加上一只船,并且跳出循环;//(3)如果最重的那个人和最轻的那个人加起来不能坐一条船,那么最重的那个人势必只能“-意孤行”了,因为其他人更加不可能和他同行.转变成n-1的子问题.//(4)如果最重的那个人可以和最轻的人一起坐一条船,那就顺带捎上,转变成n-2的子问题.
                i++;}
            j--;}return n - i;}

🌟 总结

大家一定要慢慢养成习惯,习惯刷题并且爱上它,我相信,到了后面你自己也会忍不住自己找题来刷。😎😎😎
坚持!加油!你可以的!😎😎😎

在这里插入图片描述


本文转载自: https://blog.csdn.net/weixin_56321113/article/details/123313279
版权归原作者 上火不找我 所有, 如有侵权,请联系我们删除。

“【LeedCode每周总结】还在犹豫怎么刷LeedCode有没有用?快来加入每日刷题卷进大厂吧,冲冲冲”的评论:

还没有评论