数据结构——算法之(025)( 求一个数组的最长递减子序列)
来源:互联网 发布:红叶知弦 编辑:程序博客网 时间:2024/05/20 23:34
【申明:本文仅限于自我归纳总结和相互交流,有纰漏还望各位指出。 联系邮箱:Mr_chenping@163.com】
题目:
创新工场(算法):求一个数组的最长递减子序列 比如{9,4,3,2,5,4,3,2}的最长递减子序列为{9,5,4,3,2}
题目分析:
一、这个题目类似:在一个字符串中求最长数字串
(1)快慢指针操作,每次指针调整前,先保存上一次的值
(2)如果遇到当前值比上一次值大,则把上一次快慢指针之间的数值拷贝到输出缓冲区中
算法实现:
#include <stdio.h>#include <string.h>int count_max_decrease_array(int *array, int size, int *output_array){ int *fast = array; int *slow = array;int temp = 0; int i = 0, max_digit_len = 0, tmp_len = 0; for(; i<size; ++i) { if(*fast >= *slow){ slow = fast++; continue; } temp = *fast++; if(*fast >= temp || i == (size-1)) { tmp_len = (fast - slow); if(tmp_len > max_digit_len) { max_digit_len = tmp_len; memcpy(output_array, slow, tmp_len*sizeof(int)); } tmp_len = 0; slow = fast; } } return max_digit_len;}void print(int *array, int max){printf("max = %d\n", max);int i=0;for(; i<max; ++i)printf(" %d", array[i]);printf("\n");}int main(int argc, char *argv[]){ //int in[]={1, 2, 3, 4, 5,}; int in[]={9, 4, 3, 2,100, 99, 88, 77, 66, 6, 5, 4, 8, 3, 2};int out[128]={0}; int max = count_max_decrease_array(in, sizeof(in)/sizeof(int), out);print(out, max);return 0;}
0 0
- 数据结构——算法之(025)( 求一个数组的最长递减子序列)
- 算法 - 求一个数组的最长递减子序列(C++)
- 求数组的最长递减子序列 (dp)
- 求一个数组的最长递减子序列
- 求一个数组的最长递减子序列
- 求一个数组的最长递减子序列
- 求一个数组的最长递减子序列
- 求一个数组的最长递减子序列
- 求一个数组的最长递减子序列
- 求数组的最长递减子序列
- 计蒜客——求数组最长递减子序列
- 求最长递减子序列(转载)
- 求一个整数数组最长递减子序列
- 计蒜客 求数组的最长递减子序列(nlogn+路径打印)
- coding - 求数组的最长递减子序列
- 计蒜客-求数组的最长递减子序列
- 47.创新工场: 求一个数组的最长递减子序列
- 求一个数组的最长递减子序列 比如{9,4,3,2,5,4,3,2}的最长递减子序列为{9,5,4,3,2}
- 浅析GLib
- Java-取得服务器当前的各种具体时间
- 磁场强度简介
- OOAD作业---设计模式---装饰者模式
- DWR学习2-回调函数异步问题
- 数据结构——算法之(025)( 求一个数组的最长递减子序列)
- 利用Cookie显示用户上次访问网站的时间
- Redis应用场景
- ActiveMQ安装与运行
- CHD4安装hadoop2.0
- hdu 4770 Lights Against Dudely
- 基于linux2.6.30.4内核的DM9000网卡驱动编译成模块成功ping通
- 回收站的文件清空了怎么才能找回来呢
- POI获取excel单元格的内容