码迷,mamicode.com
首页 > 其他好文 > 详细

【日记】12.19

时间:2019-12-20 21:04:05      阅读:64      评论:0      收藏:0      [点我收藏+]

标签:pac   scanf   第一个   思路   下标   std   clu   void   namespace   

12.19

DP

  1. P1091:找出最高的合唱队形。

思路:dp1[i]表示以i为最后一个人,1-i中的LIS,dp2[i]表示以i为第一个人,i-n中的LDS。dp1从前往后跑,dp2从后往前跑。注意一下,不是从前往后的LDS。

#include<bits/stdc++.h>
using namespace std;
const int M=140;
int a[M],n,ans[M];
struct LIS{
    int dp[M],d[M];
    void run(){
        int len=0;
        for(int i=1;i<=n;++i){
            int p=lower_bound(d+1,d+len+1,a[i])-d;//找到第一个大于等于a[i]的下标
            dp[i]=p,d[p]=a[i];
            if (p>len)
                len=p;
        }
    }
}L1;
struct LDS{
    int dp[M],d[M];
    void run(){
        int len=0;
        for(int i=n;i>=1;--i){
            int p=lower_bound(d+1,d+len+1,a[i])-d;//找到第一个大于等于a[i]的下标
            dp[i]=p,d[p]=a[i];
            if (p>len)
                len=p;
        }
    }
}L2;
int main(){
    scanf("%d",&n);
    for(int i=1;i<=n;++i)
        scanf("%d",&a[i]);
    L1.run(),L2.run();
    int ans=0;
    for(int i=1;i<=n;++i)
        ans=max(ans,L1.dp[i]+L2.dp[i]-1);
    printf("%d\n",n-ans);
    return 0;
}

【日记】12.19

标签:pac   scanf   第一个   思路   下标   std   clu   void   namespace   

原文地址:https://www.cnblogs.com/diorvh/p/12074581.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!