博客
关于我
sdnu1172.Queue(双向LIS)
阅读量:286 次
发布时间:2019-03-01

本文共 1681 字,大约阅读时间需要 5 分钟。

为了求解剩下的学生能够形成的最长满足左递增右递减条件的子序列,我们可以分别计算递增子序列(LIS)和递减子序列(LDS)的长度。最终答案即为这两个长度中的较大者。

方法思路

  • 问题分析:我们需要找到一个子序列,使得从左到右递增,然后从某个点开始递减。这个子序列可以是纯递增、纯递减,或者两者兼有。
  • 动态规划:使用两个数组dp1dp2分别记录每个位置作为递增子序列末尾和递减子序列末尾的情况。dp1[i]表示前i个元素的最长递增子序列长度,dp2[i]表示前i个元素的最长递减子序列长度。
  • 计算递增和递减子序列:通过遍历每个元素,更新dp1dp2数组,填充递增和递减子序列的长度。
  • 结果计算:答案即为递增子序列长度和递减子序列长度中的最大值。
  • 解决代码

    #include 
    #include
    using namespace std;int main() { int n; while (true) { scanf("%d", &n); if (n == 0) break; vector
    height(n); for (int i = 0; i < n; ++i) { scanf("%d", &height[i]); } vector
    dp1(n + 1, 1); vector
    dp2(n + 1, 1); for (int i = 2; i <= n; ++i) { int max_inc = 1; for (int j = 1; j < i; ++j) { if (height[j] < height[i-1]) { if (dp1[j] + 1 > dp1[i]) { dp1[i] = dp1[j] + 1; } } } int max_dec = 1; for (int j = 1; j < i; ++j) { if (height[j] > height[i-1]) { if (dp2[j] + 1 > dp2[i]) { dp2[i] = dp2[j] + 1; } } } } int lis = *max_element(dp1.begin() + 1, dp1.end()); int lds = *max_element(dp2.begin() + 1, dp2.end()); int ans = max(lis, lds); printf("%d\n", ans); } return 0;}

    代码解释

  • 读取输入:从标准输入读取学生人数和每个学生的身高。
  • 初始化数组dp1dp2数组初始化为1,表示每个位置自身的子序列长度。
  • 更新递增子序列:遍历每个元素,更新dp1数组,记录前面比当前小的元素的最长递增子序列。
  • 更新递减子序列:同样地,更新dp2数组,记录前面比当前大的元素的最长递减子序列。
  • 计算结果:取递增子序列和递减子序列长度的最大值作为最终答案。
  • 通过这种方法,我们可以高效地解决问题,确保在合理的时间复杂度内找到最优解。

    转载地址:http://ksio.baihongyu.com/

    你可能感兴趣的文章
    OSPF在大型网络中的应用:高效路由与可扩展性
    查看>>
    OSPF太难了,这份OSPF综合实验请每位网络工程师查收,周末弯道超车!
    查看>>
    OSPF技术入门(第三十四课)
    查看>>
    OSPF技术连载10:OSPF 缺省路由
    查看>>
    OSPF技术连载11:OSPF 8种 LSA 类型,6000字总结!
    查看>>
    OSPF技术连载12:OSPF LSA泛洪——维护网络拓扑的关键
    查看>>
    OSPF技术连载13:OSPF Hello 间隔和 Dead 间隔
    查看>>
    OSPF技术连载14:OSPF路由器唯一标识符——Router ID
    查看>>
    OSPF技术连载15:OSPF 数据包的类型、格式和邻居发现的过程
    查看>>
    OSPF技术连载16:DR和BDR选举机制,一篇文章搞定!
    查看>>
    OSPF技术连载17:优化OSPF网络性能利器——被动接口!
    查看>>
    OSPF技术连载18:OSPF网络类型:非广播、广播、点对多点、点对多点非广播、点对点
    查看>>
    OSPF技术连载19:深入解析OSPF特殊区域
    查看>>
    SQL Server 复制 订阅与发布
    查看>>
    OSPF技术连载20:OSPF 十大LSA类型,太详细了!
    查看>>
    OSPF技术连载21:OSPF虚链路,现代网络逻辑连接的利器!
    查看>>
    OSPF技术连载22:OSPF 路径选择 O > O IA > N1 > E1 > N2 > E2
    查看>>
    OSPF技术连载2:OSPF工作原理、建立邻接关系、路由计算
    查看>>
    OSPF技术连载5:OSPF 基本配置,含思科、华为、Junifer三厂商配置
    查看>>
    OSPF技术连载6:OSPF 多区域,近7000字,非常详细!
    查看>>