题解 | 合唱队形

合唱队形

https://www.nowcoder.com/practice/0045cd3e39634a66ada63c2adeb49234

#include <stdio.h>

int main() {
    int n;
    scanf("%d", &n);
    int arr[n];
    int dp_l[n];
    int dp_r[n];
    for (int i = 0; i < n; i++) {
        scanf("%d", &arr[i]);
        dp_r[i] = dp_l[i] = 1;
    }
    //计算左侧最长递增子序列
    for (int i = 1; i < n; i++) {
        for (int j = 0; j < i; j++) {
            if (arr[i] > arr[j]) {
                dp_l[i] = dp_l[i] > dp_l[j] + 1 ? dp_l[i] : dp_l[j] + 1;
            }
        }
    }
    //计算右侧最长递减子序列
    for (int i = n - 2; i >= 0; i--) {
        for (int j = n - 1; j > i; j--) {
            if (arr[i] > arr[j]) {
                dp_r[i] = dp_r[j] + 1 > dp_r[i] ? dp_r[j] + 1 : dp_r[i];
            }
        }
    }
    int max = 0;
    for (int i = 0; i < n; i++) {
        if (dp_r[i] + dp_l[i] > max) {
            max = dp_l[i] + dp_r[i] - 1;
        }
    }
    printf("%d", n - max);
    return 0;
}

#我的实习求职记录#
全部评论

相关推荐

Jcwemz:中软证书写单行,考了什么学了什么相关技术栈的内容就说自己会什么, 没实习就包装实习简历,将项目经历写成实习做的,项目时间拉长,项目成果具体化,测试的项目成果无非就是写了多少用例查出了多少bug,重要的不是实习了多久,而是你会多少东西,你能表达的就都是你的。 cet4,随便找个地方标上就好了,不用写单行。 粗略建议,我也不在行,觉得对的可以采纳
实习,投递多份简历没人回...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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