【面试经典150】day 7

目录

[1.买卖股票的最佳时机 II](#1.买卖股票的最佳时机 II)

2.跳跃游戏

[3.跳跃游戏 II](#3.跳跃游戏 II)

[4.H 指数](#4.H 指数)

[5.O(1) 时间插入、删除和获取随机元素](#5.O(1) 时间插入、删除和获取随机元素)

6.除自身以外数组的乘积

7.加油站

8.分发糖果

1.买卖股票的最佳时机 II

java 复制代码
class Solution {
    public int maxProfit(int[] prices) {
        //和1相比,这个可以一直买卖股票,所以可以使用贪心策略,因为局部最优解就是全局最优解
        //亏钱直接不买卖
        int profit=0;
        for(int i=1;i<prices.length;i++){
            int tmp=prices[i]-prices[i-1];
            if(tmp>0) profit+=tmp;
        }
        return profit;
    }
}

2.跳跃游戏

最右可达位置维护。

有点类似拼接的路段。

java 复制代码
class Solution {
    public boolean canJump(int[] nums) {
        int mx=0;
        for(int i=0;i<nums.length;i++){
            if(i>mx){
                //无法到达i
                return false;
            }
            //最右可以跳到i+nums[i]
            mx=Math.max(mx,i+nums[i]);
        }
        return true;
    }
}

3.跳跃游戏 II

java 复制代码
class Solution {
    public int jump(int[] nums) {
        int ret=0;
        //已建造的桥的右端点
        int cur_right=0;
        //下一座桥的右端点最大值
        int next_right=0;
        for(int i=0;i<nums.length-1;i++){
            next_right=Math.max(next_right,i+nums[i]);
            //到达已造桥的右端点
            if(i==cur_right){
                cur_right=next_right;
                ret++;
            }
        }
        return ret;
    }
}

4.H 指数

java 复制代码
class Solution {
    public int hIndex(int[] citations) {
        int n=citations.length;
        //cnt统计引用次数的出现次数
        int [] cnt=new int [n+1];
        for(int c:citations){
            //min是处理>n的引用次数,归为n
            cnt[Math.min(c,n)]++;
        }
        int sum=0;
        //倒序遍历更好,一旦符合马上接收
        for(int i=n;;i--){
            sum+=cnt[i];
            if(sum>=i){
                return i;
            }
        }
    }
}

5.O(1) 时间插入、删除和获取随机元素

java 复制代码
class RandomizedSet {
    static int[] nums=new int[200010];
    Random random=new Random();
    Map<Integer,Integer>map=new HashMap<>();
    int idx=-1;

    public boolean insert(int val) {
        if(map.containsKey(val)) return false;
        nums[++idx]=val;
        map.put(val,idx);
        return true;       
    }
    
    public boolean remove(int val) {
        if(!map.containsKey(val)) return false;
        int loc=map.remove(val);
        if(loc!=idx) map.put(nums[idx],loc);
        nums[loc]=nums[idx--];
        return true;
    }
    
    public int getRandom() {
        return nums[random.nextInt(idx+1)];
    }
}

/**
 * Your RandomizedSet object will be instantiated and called as such:
 * RandomizedSet obj = new RandomizedSet();
 * boolean param_1 = obj.insert(val);
 * boolean param_2 = obj.remove(val);
 * int param_3 = obj.getRandom();
 */

6.除自身以外数组的乘积

java 复制代码
class Solution {
    public int[] productExceptSelf(int[] nums) {
       //pre表示前缀积;suf表示后缀积;ret=两者之积即可;
       int n=nums.length;
       int[] pre=new int[n];
       pre[0]=1;
       for(int i=1;i<n;i++){
          pre[i]=nums[i-1]*pre[i-1];
       }

       int[] suf=new int[n];
       suf[n-1]=1;
       for(int i=n-2;i>=0;i--){
        suf[i]=nums[i+1]*suf[i+1];
       }

       int[] ret = new int[n];
       for(int i=0;i<n;i++){
        ret[i]=pre[i]*suf[i];
       }

       return ret;
    }
}

7.加油站

java 复制代码
class Solution {
    public int canCompleteCircuit(int[] gas, int[] cost) {
        int ret=0;
        //最小油量
        int mins=0;
        //油量
        int s=0;
        for(int i=0;i<gas.length;i++){
            //i处加油,从i到i+1
            s+=gas[i]-cost[i];
            if(s<mins){
                //更新最小油量
                mins=s;
                ret=i+1;
            }
        }
        //循环结束后,s 即为 gas 之和减去 cost 之和
        return s<0?-1:ret;
    }
}

8.分发糖果

java 复制代码
class Solution {
    public int candy(int[] ratings) {
        //贪心算法
        int [] left=new int[ratings.length];
        int [] right=new int[ratings.length];
        //都发一颗糖
        Arrays.fill(left,1);
        Arrays.fill(right,1);
        for(int i=1;i<ratings.length;i++){
            if(ratings[i]>ratings[i-1]) left[i]=left[i-1]+1;
        }
        int count=left[ratings.length-1];
        for(int i = ratings.length - 2; i >= 0; i--) {
            if(ratings[i] > ratings[i + 1]) right[i] = right[i + 1] + 1;
            count += Math.max(left[i], right[i]);
        }
        return count;     
    }
}
相关推荐
老鼠只爱大米1 分钟前
LeetCode经典算法面试题 #78:子集(回溯法、迭代法、动态规划等多种实现方案详细解析)
算法·leetcode·动态规划·回溯·位运算·子集
代码栈上的思考3 分钟前
SpringBoot 拦截器
java·spring boot·spring
-Springer-3 分钟前
STM32 学习 —— 个人学习笔记5(EXTI 外部中断 & 对射式红外传感器及旋转编码器计数)
笔记·stm32·学习
消失的旧时光-19434 分钟前
C++ 拷贝构造、拷贝赋值、移动构造、移动赋值 —— 四大对象语义完全梳理
开发语言·c++
执着2595 分钟前
力扣hot100 - 199、二叉树的右视图
数据结构·算法·leetcode
送秋三十五6 分钟前
一次大文件处理性能优化实录————Java 优化过程
java·开发语言·性能优化
I_LPL9 分钟前
day21 代码随想录算法训练营 二叉树专题8
算法·二叉树·递归
雨中飘荡的记忆9 分钟前
千万级数据秒级对账!银行日终批处理对账系统从理论到实战
java
jbtianci14 分钟前
Spring Boot管理用户数据
java·spring boot·后端
可编程芯片开发16 分钟前
基于PSO粒子群优化PI控制器的无刷直流电机最优控制系统simulink建模与仿真
人工智能·算法·simulink·pso·pi控制器·pso-pi