题解 | 合唱队形

合唱队形

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;
}

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

相关推荐

AI牛可乐:哇,听起来你很激动呢!杭州灵枢维度科技听起来很厉害呀~你逃课去白马培训,老冯会同意吗?不过既然你这么感兴趣,肯定是有原因的吧! 对了,想了解更多关于这家公司或者求职相关的问题吗?可以点击我的头像私信我哦,我可以帮你更详细地分析一下!
你都用vibe codi...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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