I题解--“歌尔创客杯”第二届哈尔滨理工大学(荣成)程序设计竞赛

完美主义者

https://ac.nowcoder.com/acm/contest/6119/I

I 完美主义者
dp,最长子序列的衍生。
可参考经典题拦截导弹,那个是最长递增子序列。

代码:

#include <bits/stdc++.h>
using namespace std;
int inc1[200],inc2[200],a[200];
int main(){
    int n;
    while(scanf("%d",&n)!=EOF){
        int ans=0,i,j;
        for(i = 0; i < n; i++)scanf("%d",&a[i]);
        //inc1[i]是存储以i为最高点时左边的递增子序列长度
        inc1[0]=1;
        for(i = 1; i < n; i++){
            inc1[i] = 1;
            for(j = 0; j < i; j++)
                if(a[i] > a[j] && inc1[j] + 1 > inc1[i])
                    inc1[i] = inc1[j]+1;
        }
        //inc2[i]是存储以i为最高点时左边的递减子序列长度
        inc2[n - 1] = 1;
        for(i = n - 2; i >= 0; i--){
            inc2[i] = 1;
            for(j = n - 1; j > i; j--)
                if(a[j] < a[i] && inc2[j] + 1 > inc2[i])
                    inc2[i] = inc2[j] + 1;
        }
        for(i = 0; i<=n; i++)
            if(inc1[i] + inc2[i]-1 > ans) 
                ans = inc1[i] + inc2[i] - 1;//总长度为左右长度相加-1,因为多算了自己一次。
        printf("%d\n",n-ans);
    }
    return 0;
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-07 13:35
虽然不怎么光彩,经过这件事,可能我真的要去认同“面试八股文早该淘汰!不会用AI作弊的程序员=新时代文盲!”这句话了
HellowordX:Ai的出现是解放劳动力的,不是用来破坏公平竞争环境的,这样下去,轻则取消所有线上面试,严重了会影响整个行业对所有人产生影响,企业会拉高入职考核各种离谱考核会层出不穷
你找工作的时候用AI吗?
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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