题解 | 最大上升子序列和 ,简单动态规划改版

最大上升子序列和

https://www.nowcoder.com/practice/dcb97b18715141599b64dbdb8cdea3bd

原来的状态转移方程: DP[i]=max(DP[i],DP[j]+1);

新的状态转移方程只是把权重1变成sequences[i](假设数据输入在sequences[i]中),DP[i]=max(DP[i],DP[j]+sequences[i]);

同时原来DP数组初始化为1即可,现在DP数组初始化为sequences[i],即:for(int i=0;i<n;i++)DP[i]=sequences[i];

#include <iostream>
#include <vector>
using namespace std;

int main() {
    int n;
    while (cin >> n) { // 注意 while 处理多个 case
        vector<int> sequences(n);
        for(int i=0;i<n;i++){
            cin>>sequences[i];
        }
        int res=sequences[0];
        vector<int> DP(n,0);
        for(int i=0;i<n;i++) DP[i]=sequences[i];
        
        for(int i=1;i<n;i++){
            for(int j=0;j<i;j++){
                if(sequences[i]>sequences[j]){
                    DP[i]=max(DP[i],DP[j]+sequences[i]);
                    if(res<DP[i]) res=DP[i];
                }
            }
        }
        cout<<res<<endl;
    }
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

09-16 17:32
门头沟学院 Java
顺顺超爱学:1.熟悉Java编程语言,熟悉集合,多线程,IO,反射等核心知识,了解线程池,ThreadLocal等进阶知识; 2.熟悉Mysql数据库,熟练使用sql,熟悉索引,存储引擎,事务原理,MVCC,锁机制,了解sql优化; 3.熟悉Redis缓存,了解常见的数据类型,了解缓存常见问题及其解决方案,了解使用Redis实现的分布式锁方案; 4.熟悉Javaweb开发框架,熟悉spring,springmvc,mybatis等,了解IOC,AOP等; 5.熟悉微服务开发框架,熟悉SpringBoot,SpringCloud,包括Nacos,OpenFeign,Gateway等核心组件; 6.熟悉Rabbitmq消息队列,熟练使用消息模型,了解架构,消息可靠性,死信队列,延迟消息等;
点赞 评论 收藏
分享
09-21 23:16
门头沟学院 Java
传奇逃兵王:招不起就别招,叽里咕噜说啥呢
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务