【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();
    }
}
相关推荐
Ai马猴子几秒前
企业定制专属模型,gpt-5.4-cdx高效适配,DMXAPI 安全合规
java·gpt·安全
2301_789015621 分钟前
Linux:基础指令(二)
linux·运维·服务器·c语言·开发语言·c++·算法
开开心心就好2 分钟前
支持添加网址的资源快速打开工具
人工智能·学习·游戏·音视频·hbase·语音识别·storm
星晨羽5 分钟前
Java通过FTP协议实现文件上传下载
java·开发语言
逸Y 仙X5 分钟前
文章三十:Elasticsearch SQL实战案例
java·大数据·sql·elasticsearch·搜索引擎·全文检索
sheeta19986 分钟前
TypeScript 学习笔记
笔记·学习·typescript
闻缺陷则喜何志丹6 分钟前
【区间合并】P7912 [CSP-J 2021] 小熊的果篮|普及+
c++·算法·洛谷·区间合并
小则又沐风a7 分钟前
初步了解进程的概念
java·linux·服务器·前端
斌果^O^7 分钟前
普通 SpringBoot 单体项目改造成微服务(Nacos+Gateway + 内部服务免鉴权)
java·spring boot·spring
摩羯座-小齐7 分钟前
java excel级联下拉框
java·excel