牛客:HJ24 合唱队[华为机考][最长递增子集][动态规划]

学习要点

  1. 求最长递增字列
  2. 求最长递减子列

题目链接

合唱队_牛客题霸_牛客网

题目描述

解法:动归求最长递增子列

cpp 复制代码
#include <iostream>
#include <vector>
using namespace std;

int main() {
    int n;
    while (cin >> n) {
        // 输入的数组
        int tmp;
        vector<int> v;
        for (int i = 0; i < n; ++i) {
            cin >> tmp;
            v.push_back(tmp);
        }

        // 最长递增子序列 从左往右
        if (v.empty()) return 0;
        vector<int> dp1(n, 1);
        for (int i = 0; i < n; ++i) {
            for (int j = 0; j <  i ; ++j) {
                if (v[i] > v[j]) {
                    dp1[i] = max(dp1[i], dp1[j] + 1);
                }
            }
        }
        // 最长递减子序列 从右往左
        if (v.empty()) return 0;
        vector<int> dp2(n, 1);
        for(int i = n-1;i>=0;i--)
        {
            for(int j = n-1;j>i;j--)
            {
                if(v[i] > v[j])
                {
                    dp2[i] = max(dp2[i],dp2[j]+1);
                }
            }
        }

        int result;
        for(int i =0;i<n;i++)
        {
            result = max(result,dp1[i]+dp2[i]-1);
        }
        cout << n - result;


    }
}
// 64 位输出请用 printf("%lld")
相关推荐
AKDreamer_HeXY14 小时前
ABC434E 题解
c++·算法·图论·atcoder
罗湖老棍子14 小时前
完全背包 vs 多重背包的优化逻辑
c++·算法·动态规划·背包
TL滕14 小时前
从0开始学算法——第四天(题目参考答案)
数据结构·笔记·python·学习·算法
potato_may14 小时前
C++ 发展简史与核心语法入门
开发语言·c++·算法
Liangwei Lin14 小时前
洛谷 P1443 马的遍历
数据结构·算法
老鱼说AI14 小时前
算法基础教学第二步:数组(超级详细原理级别讲解)
数据结构·神经网络·算法·链表
小白程序员成长日记14 小时前
2025.12.01 力扣每日一题
算法·leetcode·职场和发展
爱装代码的小瓶子14 小时前
【cpp知识铺子】map和set的前身-二叉搜索树
c++·算法
TL滕15 小时前
从0开始学算法——第四天(练点题吧)
数据结构·笔记·学习·算法
[J] 一坚15 小时前
华为OD、微软、Google、神州数码、腾讯、中兴、网易有道C/C++字符串、数组、链表、树等笔试真题精粹
c语言·数据结构·c++·算法·链表