牛客: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")
相关推荐
无敌昊哥战神5 分钟前
【算法与数据结构】深入浅出回溯算法:理论基础与核心模板(C/C++与Python三语解析)
c语言·数据结构·c++·笔记·python·算法
輕華8 分钟前
OpenCV三大传统人脸识别算法:EigenFace、FisherFace与LBPH实战
人工智能·opencv·算法
akarinnnn9 分钟前
【DAY16】字符函数和字符串函数
c语言·数据结构·算法
_日拱一卒15 分钟前
LeetCode:螺旋矩阵
算法·leetcode·矩阵
Tairitsu_H19 分钟前
C语言:排序(二)
c语言·开发语言·算法
Q741_1471 小时前
每日一题 力扣 1848. 到目标元素的最小距离 模拟 C++题解
c++·算法·leetcode·模拟
VkN2X2X4b2 小时前
算法性能的渐近与非渐近行为对比的技术9
算法
好家伙VCC2 小时前
**神经编码新视角:用Python实现生物启发的神经信号压缩与解码算法**在人工智能飞速发展的今天
java·人工智能·python·算法
见山是山-见水是水7 小时前
鸿蒙flutter第三方库适配 - 读书笔记
flutter·华为·harmonyos
Utopia^8 小时前
鸿蒙flutter第三方库适配 - 图片压缩工具
flutter·华为·harmonyos