面试经典150题(5-7)

leetcode 150道题 计划花两个月时候刷完,今天(第二天)完成了三道(5-7)150:

  1. (169. 多数元素) 题目描述:
bash 复制代码
给定一个大小为 n 的数组 nums ,返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。
你可以假设数组是非空的,并且给定的数组总是存在多数元素。

第一版(这个我是一次就写出来了,这个就是投票的简单类型,当然今天这个最多元素也可以排序后直接返回中间元素也行)

java 复制代码
class Solution {
    public int majorityElement(int[] nums) {
        int len=nums.length;
        if(len<=2){
            return nums[0];
        }
        int res=1;
        int temp=nums[0];
        for(int i=1;i<len;i++){
            if(temp==nums[i]){
                res++;
            }else{
                if(res==0){
                    res=1;
                    temp=nums[i];
                }
                res--;
            }
        }
        return temp;
    }
}
  1. (189. 轮转数组)题目描述:
bash 复制代码
给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。

第一版(确实刚开始没想到好办法,就用了数组暂存,然后登挪完其他的,把这些加到数组头部,但是这种题必须先求余!!)

java 复制代码
class Solution {
    public void rotate(int[] nums, int k) {
        int len=nums.length;
        if(len<=1)
            return ;
        int count=k%len;
        int[] temp=new int[count];
        for(int i=0;i<count;i++)
        {
            temp[i]=nums[i+len-count];
        }
        for(int i=len-count-1;i>=0;i--){
            nums[i+count]=nums[i];
        }
        for(int i=0;i<count;i++){
            nums[i]=temp[i];
        }
    }
}

第二版(看完解析恍然大悟,希望我下次再碰到了能直接恍然大悟)

java 复制代码
class Solution {
    public void rotate(int[] nums, int k) {
        int len=nums.length;
        if(len<=1)
            return;
        int count=k%len;
        if(count==0)
            return ;
        // 反转
        reserve(nums,0,len-1);
        // 再反转 前半部分(【0-count-1】)
        reserve(nums,0,count-1);
        // 再反转 后半部分(【count-len-1】)
        reserve(nums,count,len-1);
    }
    public void reserve(int[] nums,int first,int last){
        while(first<last){
            int temp=nums[last];
            nums[last--]=nums[first];
            nums[first++]=temp;
        }
    }
}
  1. (121. 买卖股票的最佳时机)题目描述:
bash 复制代码
给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。
你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。
返回你可以从这笔交易中获取的最大利润。如果你不能获取任何利润,返回 0 。

第一版(这个题我也是已经刷了好多遍了,还是记不住啊,还是没思路就直接暴力求解了,但是 leetcode 能过,哈哈哈)

java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        int res=0;
        int temp=Integer.MAX_VALUE;
        for(int i=0;i<prices.length-1;i++){
            if(prices[i]>=temp)
                continue;
            temp=prices[i];
            for(int j=i+1;j<prices.length;j++){
                res=Math.max(res,prices[j]-prices[i]);
            }
        }
        return res;
    }
}

第二版(翻了解题的评论才明白了--"降价时候找最低价--涨价时候 算差价")

java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        // 降价时候找最低价--涨价时候 算差价 牛
        int minPrice=Integer.MAX_VALUE;
        int res=0;
        for(int price:prices){
            if(price<minPrice){
                minPrice=price;
            }else{
                res=Math.max(res,price-minPrice);
            }
        }
        return res;
    }
}

今天看了三个题有进步,加油!!!

我们的目标是早日跳槽!!!!

相关推荐
JCBP_13 分钟前
数据结构3
服务器·c语言·数据结构·vscode
yuanbenshidiaos22 分钟前
面试问题总结:qt工程师/c++工程师
c++·qt·面试
半盏茶香27 分钟前
启幕数据结构算法雅航新章,穿梭C++梦幻领域的探索之旅——堆的应用之堆排、Top-K问题
java·开发语言·数据结构·c++·python·算法·链表
uhakadotcom31 分钟前
Langflow:打造AI应用的强大工具
前端·面试·github
uhakadotcom38 分钟前
🤖 LangGraph 多智能体群集
面试·架构·github
小竹子141 小时前
L1-1 天梯赛座位分配
数据结构·c++·算法
董董灿是个攻城狮1 小时前
Transformer 通关秘籍8:词向量如何表示近义词?
算法
uhakadotcom1 小时前
Caddy Web服务器初体验:简洁高效的现代选择
前端·面试·github
独好紫罗兰1 小时前
洛谷题单2-P5712 【深基3.例4】Apples-python-流程图重构
开发语言·python·算法
uhakadotcom2 小时前
NVIDIA Resiliency Extension(NVRx)简介:提高PyTorch训练的容错性
算法·面试·github