【Java】零基础蓝桥杯算法学习——线性动态规划(一维dp)

线性dp------一维动态规划

1、考虑最后一步可以由哪些状态得到,推出转移方程

2、考虑当前状态与哪些参数有关系,定义几维数组来表示当前状态

3、计算时间复杂度,判断是否需要进行优化。

一维动态规划例题:最大上升子序列问题

Java参考代码:

java 复制代码
import java.util.Scanner;

public class Main {
    public static void main(String[] args)  {
       Scanner scan = new Scanner(System.in);
       int n = scan.nextInt();
       int[] a = new int[n];
       for(int i=0;i<n;i++) {
    	   a[i]=scan.nextInt();
       }
       int[] dp = new int[n];
       dp[0]=1;
       int max=1;
       for(int i=1;i<n;i++) {
    	   dp[i]=1;
    	   for(int j=0;j<i;j++) {
    		   if(a[i]>a[j]) {
    			   dp[i]=Math.max(dp[i], dp[j]+1);
    		   }
    	   }
    	   max = Math.max(dp[i], max);
       }
       System.out.println(max);
       scan.close();
    }
}
相关推荐
GFCGUO16 分钟前
ubuntu18.04运行OpenPCDet出现的问题
linux·python·学习·ubuntu·conda·pip
快乐就好ya41 分钟前
Java多线程
java·开发语言
IT学长编程1 小时前
计算机毕业设计 二手图书交易系统的设计与实现 Java实战项目 附源码+文档+视频讲解
java·spring boot·毕业设计·课程设计·毕业论文·计算机毕业设计选题·二手图书交易系统
CS_GaoMing1 小时前
Centos7 JDK 多版本管理与 Maven 构建问题和注意!
java·开发语言·maven·centos7·java多版本
Indigo_code1 小时前
【数据结构】【顺序表算法】 删除特定值
数据结构·算法
艾伦~耶格尔2 小时前
Spring Boot 三层架构开发模式入门
java·spring boot·后端·架构·三层架构
丝丝不是土豆丝2 小时前
学习 CSS 新的属性 conic-gradient 实现环形进度条
学习
man20172 小时前
基于spring boot的篮球论坛系统
java·spring boot·后端
阿史大杯茶2 小时前
Codeforces Round 976 (Div. 2 ABCDE题)视频讲解
数据结构·c++·算法
2401_858120532 小时前
Spring Boot框架下的大学生就业招聘平台
java·开发语言