力扣打卡(12) :差点摸鱼了... 力扣每日水题

18 篇文章 0 订阅
16 篇文章 0 订阅
博主因研究juc锁的源码而耽误了力扣的每日刷题,补做了414. 第三大的数、287. 寻找重复数等题目。414题可以通过排序或使用TreeSet解决,287题应用了抽屉原理的二分法解题,非常有趣。
摘要由CSDN通过智能技术生成
### 10.6 10.7lc

罪恶 罪恶 摸鱼了两天。一直在看juc的lock 的源码和aqs框架~~

忘了刷了 就写了力扣的每日易题

414. 第三大的数 - 力扣(LeetCode) (leetcode-cn.com)

方法很多 :可以排序 再找

可以用 treeSet来满足要求

可以线性遍历

class Solution {
    public int thirdMax(int[] nums) {
        //  long  是个坑。。。。。。
            long  max1 =Long.MIN_VALUE;
            long max2=Long.MIN_VALUE;
            long max3 =Long.MIN_VALUE;
          
           
            
// 传统的第二大数  的变形 只不过为了过 测试  改成 long
            for(int x : nums){
                if(x>max1){
                    max3=max2;
                    max2=max1;
                    max1=x;
                }else if(x>max2 && x<max1){
                    max3=max2;
                    max2=x;
                }else if(x<max2 && x>max3){
                    max3=x;
                }
            }
            //   强转 int
            return max3 == Long.MIN_VALUE ? (int)max1:(int)max3 ;
    }
}

287. 寻找重复数 - 力扣(LeetCode) (leetcode-cn.com)

:思路 很有意思的一道 :又是玄学二分的一道题:

不是在本身的数组进行的 而是一个有序的新数组 实现 : 抽屉原理:

class Solution {
    public int findDuplicate(int[] nums) {
      
        int len = nums.length;
        int left = 1;
        int right = len - 1;
        while (left < right) {
            int mid = left + (right - left) / 2;

            int cnt = 0;
            for (int num : nums) {
                if (num <= mid) {
                    cnt += 1;
                }
            }

            // 根据抽屉原理,小于等于 4 的个数如果严格大于 4 个,此时重复元素一定出现在 [1..4] 区间里
            if (cnt > mid) {
                // 重复元素位于区间 [left..mid]
                right = mid;
            } else {
                // if 分析正确了以后,else 搜索的区间就是 if 的反面区间 [mid + 1..right]
                left = mid + 1;
            }
        }
        return left;
    }

    
}

434. 字符串中的单词数 - 力扣(LeetCode) (leetcode-cn.com)

超级水题 api调用师 上线

class Solution {
    public int countSegments(String s) {
      return s.split(" ").length;
    }
}
  • List item
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值