题解 | #合唱队#

合唱队

https://www.nowcoder.com/practice/6d9d69e3898f45169a441632b325c7b4

#include <iostream>
#include <vector>
using namespace std;
// 要求一侧递增另一侧递减,可以通过双数组分别计算两侧的策略来简化问题
int main()
{
    int num;
    cin >> num;
    vector<int>heights(num,0);
    for(int i = 0;i<num;i++)
    {
        cin >> heights[i];
    }
    vector<int>dp_l(num,1);
    vector<int>dp_r(num,1);
    for(int i = 1;i<num;i++)
    {
        for(int j = 0;j<i;j++)
        {
            if(heights[i] > heights[j])
            {
                dp_l[i] = max(dp_l[j] + 1,dp_l[i]);
            }
            if(heights[num-1 - i] > heights[num - 1 - j])
            {
                dp_r[num-1 - i] = max(dp_r[num - 1 - i],dp_r[num-1 - j]+1);
            }
        }
    }
    int maxdlete = num;
    for(int i = 0;i<num;i++)
    {
        if(dp_l[i]+dp_r[i] - 1 > num - maxdlete)
        {
            maxdlete = num - (dp_l[i]+dp_r[i] - 1);
        }
    }
    cout << maxdlete << endl;


}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

03-03 10:35
3d人士会梦见住进比弗利山庄吗:这四个项目属于是初学者的玩具了。不知道面试官咋问,而且双非本搞算法除了9,还是保守至少c9
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务