力扣动态规划-7【算法学习day.101】

前言

###我做这类文章一个重要的目的还是给正在学习的大家提供方向(例如想要掌握基础用法,该刷哪些题?建议灵神的题单和代码随想录)和记录自己的学习过程,我的解析也不会做的非常详细,只会提供思路和一些关键点,力扣上的大佬们的题解质量是非常非常高滴!!!


习题

1.最大子数组和

题目链接: 53. 最大子数组和 - 力扣(LeetCode)

题面:

附上灵神代码:

java 复制代码
class Solution {
    public int maxSubArray(int[] nums) {
        int[] f = new int[nums.length];
        f[0] = nums[0];
        int ans = f[0];
        for (int i = 1; i < nums.length; i++) {
            f[i] = Math.max(f[i - 1], 0) + nums[i];
            ans = Math.max(ans, f[i]);
        }
        return ans;
    }
}

2.找到最大开销的子字符串

题目链接: 2606. 找到最大开销的子字符串 - 力扣(LeetCode)

题面:

代码

java 复制代码
class Solution {
    Map<Character,Integer> map = new HashMap<>();
    public int maximumCostSubstring(String s, String chars, int[] vals) {
        char[] arr = chars.toCharArray();
        for(int i = 0;i<arr.length;i++){
            map.put(arr[i],vals[i]);
        }
        char[] brr = s.toCharArray();
        int n = brr.length;
        int[] f = new int[n+1];
        f[0] = 0;
        int ans = 0;
        for(int i = 1;i<=n;i++){
            f[i] = Math.max(f[i-1],0)+find(brr[i-1]);
            ans=Math.max(f[i],ans);
            // System.out.println(f[i]);
        }
        return ans;
    }
    public int find(char c){
        int flag = map.getOrDefault(c,-10000);
        if(flag!=-10000){
            return flag;
        }else{
            return c-'a'+1;
        }
    }
}

后言

上面是动态规划相关的习题,共勉

相关推荐
鱼跃鹰飞1 小时前
设计模式系列:工厂模式
java·设计模式·系统架构
a努力。1 小时前
国家电网Java面试被问:混沌工程在分布式系统中的应用
java·开发语言·数据库·git·mysql·面试·职场和发展
Yvonne爱编码2 小时前
Java 四大内部类全解析:从设计本质到实战应用
java·开发语言·python
tobias.b2 小时前
408真题解析-2010-6-数据结构-哈夫曼树
数据结构·计算机考研·408真题解析
J2虾虾2 小时前
SpringBoot和mybatis Plus不兼容报错的问题
java·spring boot·mybatis
毕设源码-郭学长2 小时前
【开题答辩全过程】以 基于springboot 的豪华婚车租赁系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
tobias.b3 小时前
408真题解析-2010-7-数据结构-无向连通图
数据结构·算法·图论·计算机考研·408真题解析
良木生香4 小时前
【鼠鼠优选算法-双指针】003:快乐数 & 004:盛水最多的容器
算法
Cx330❀4 小时前
【优选算法必刷100题】第41-42题(模拟):Z 字形变换,外观数列
c++·算法
沃尔特。4 小时前
直流无刷电机FOC控制算法
c语言·stm32·嵌入式硬件·算法