博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
求数组的最大子数组值和最长公共子序列问题
阅读量:6713 次
发布时间:2019-06-25

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

#include 
#include
using namespace std;/*求数组的子数组和的最大值分析:子数组是连续的,只用返回子数组的和,元素肯定是整数,包括正数,负数,0假设 sum存储的是数组从0第i个位置的最大子数组之和,那么第i+1个元素加入后的结果 temp = max(temp+a[i+1],a[i+1]); sum = max(sum,temp);(sum中始终存着最大和)*/int max(int a,int b){ return a>b?a:b;}int maxSum(int *arr,int n){ int temp = arr[0]; int sum = arr[0]; for (int i = 1; i < n; i++) { temp = max(temp+arr[i],arr[i]); sum = max(sum,temp); } return sum;}//最长递增、递减子序列,这里以递增子序列为例,递减子序列可以转化为递增子序列计算/*设以 len[]数组存储 以每一个元素结尾的递增子序列的最大长度,没增加一个元素,更新len[0---i]len[i] = max{1,len[k]+1} a[i]>a[k] k:[0 i-1];该方法的效率为O(N^2)*/int LIS(int *arr,int n){ int *len = (int*)malloc(sizeof(int)*n); if (len==NULL)return -1; memset(len,0,n); for(int i = 0; i < n; i++) { len[i] = 1; for (int k = 0; k < i; k++) { if (arr[i] > arr[k] && len[k]+1 > len[i]) len[i] = len[k]+1; } } int max=len[0]; for (int i = 0; i < n; i++) if(len[i]>max)max = len[i]; free(len); return max;}int main(int argc, char **argv){
int a[] = {
1,-1,2,-3,4,-5,6,-7}; int size; int i; size = sizeof(a)/sizeof(int); int res = maxSum(a,size); printf("最大子数组之和为:%d\n",res); printf("最长递增子序列:%d\n",LIS(a,size)); return 0;}

 

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

你可能感兴趣的文章
To Be an Architect : 架构的一些基本概念
查看>>
数据恢复软件哪个好
查看>>
『火车进出栈问题 卡特兰数』
查看>>
第四天:HTTP&Tomcat
查看>>
python 文件和路径操作函数小结
查看>>
条件+努力=?
查看>>
HBase分布式安装
查看>>
我为什么要录制Java Swing桌面应用程序开发课程
查看>>
201508025 课后命令练习总结
查看>>
RHEL 6.1下Apache与Tomcat整合
查看>>
安装nginx小计
查看>>
添加绿色,×××和红色区域
查看>>
linux系统中单网卡添加多个ip
查看>>
APUE读书笔记-01UNIX系统概述(1)
查看>>
APUE读书笔记-15进程内部通信-10客户服务特性
查看>>
KendoUI系列:ComboBox
查看>>
nginx日志错误日志说明
查看>>
mac下,有哪些好用的抓包工具?
查看>>
WPS Office for Mac
查看>>
Redhat5.5安装oracle11g
查看>>