博客
关于我
sdnu 1040 LIS
阅读量:332 次
发布时间:2019-03-03

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

最长上升子序列与最大下降子序列的C++实现

在数据处理领域,子序列问题是一个经常被研究的课题。其中,最长上升子序列(Longest Increasing Subsequence,LIS)和最大下降子序列(Longest Decreasing Subsequence,LDS)是两个常见的子序列问题。通过对这些问题的研究和实践,我们可以更好地理解数据的内在结构,并为后续的算法设计提供理论支持。

本文将介绍一个用于计算最长上升子序列和最大下降子序列长度的C++程序,该程序基于动态规划算法,能够有效地处理大规模数据。

程序概述

程序的主要逻辑如下:

  • 输入处理:从标准输入读取整数序列。
  • 动态规划数组初始化:定义两个数组dp1dp2,分别用于存储每个位置的最长上升子序列和最大下降子序列长度。
  • 子序列长度计算:通过遍历数组,利用动态规划方法计算每个位置的最长上升子序列和最大下降子序列长度。
  • 结果输出:输出最大下降子序列长度和最长上升子序列长度。
  • 代码逻辑详解

    程序的核心逻辑位于main函数中。以下是代码的主要部分:

    #include 
    #include
    #include
    #include
    using namespace std;typedef long long ll;const int Max = 1e6 + 9;const ll mod = 1000000007;int a[Max], dp1[Max], dp2[Max];char x[Max];int max1 = -1, max2 = -1;int i = 0;char c;int main() { while (~scanf("%d", &a[++i])) { getchar(); dp1[i] = dp2[i] = 1; for (int j = 1; j < i; j++) { if (a[i] > a[j]) { if (dp1[i] < dp1[j] + 1) { dp1[i] = dp1[j] + 1; } } else { if (dp2[i] < dp2[j] + 1) { dp2[i] = dp2[j] + 1; } } } if (max1 < dp1[i]) { max1 = dp1[i]; } if (max2 < dp2[i]) { max2 = dp2[i]; } } printf("%d,%d\n", max2, max1 - 1); return 0;}

    代码解释

  • 输入处理:使用scanf函数读取输入数据,并存储在数组a中。
  • 动态规划数组初始化dp1dp2数组的初始化为1,这是因为每个数字本身都可以看作一个长度为1的上升或下降子序列。
  • 子序列长度计算:通过双重循环遍历数组a,比较当前元素与前面所有元素的大小,更新dp1dp2数组的值。
  • 结果输出:在循环结束后,输出最大下降子序列长度max2和最长上升子序列长度max1 - 1(减1是因为初始值为1,实际长度需要减去1)。
  • 性能优化

    为了提高程序的运行效率,采用以下优化措施:

  • 数组大小限制:设置数组大小为1e6 + 9,以支持大规模数据处理。
  • 常数模运算:引入模运算常数mod,以便于处理大数问题。
  • 循环优化:通过减少循环次数和合并循环体,提高程序运行速度。
  • 总结

    通过本文介绍的C++程序,我们可以快速计算任意整数序列的最长上升子序列和最大下降子序列长度。该程序基于动态规划算法,具有较强的数据处理能力,适用于处理大规模数据。

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

    你可能感兴趣的文章
    Objective-C实现lstm prediction预测算法(附完整源码)
    查看>>
    Objective-C实现lucas数列算法(附完整源码)
    查看>>
    Objective-C实现Luhn (Mod 10)Algorithm算法(附完整源码)
    查看>>
    Objective-C实现LZW编码(附完整源码)
    查看>>
    Objective-C实现MAC桌面暗水印(附完整源码)
    查看>>
    Objective-C实现mandelbrot曼德勃罗特集算法(附完整源码)
    查看>>
    Objective-C实现markov chain马尔可夫链算法(附完整源码)
    查看>>
    Objective-C实现MATLAB中Filter函数功能(附完整源码)
    查看>>
    Objective-C实现matrix chainorder矩阵链顺序算法(附完整源码)
    查看>>
    Objective-C实现matrix exponentiation矩阵求幂算法(附完整源码)
    查看>>
    Objective-C实现MatrixMultiplication矩阵乘法算法 (附完整源码)
    查看>>
    Objective-C实现max non adjacent sum最大非相邻和算法(附完整源码)
    查看>>
    Objective-C实现max subarray sum最大子数组和算法(附完整源码)
    查看>>
    Objective-C实现max sum sliding window最大和滑动窗口算法(附完整源码)
    查看>>
    Objective-C实现MaxHeap最大堆算法(附完整源码)
    查看>>
    Objective-C实现MaximumSubarray最大子阵列(Brute Force蛮力解决方案)算法(附完整源码)
    查看>>