题解 | #最长上升子序列(三)#

最长上升子序列(三)

http://www.nowcoder.com/practice/9cf027bf54714ad889d4f30ff0ae5481

import java.util.*;


public class Solution {
    /**
     * retrun the longest increasing subsequence
     * @param arr int整型一维数组 the array
     * @return int整型一维数组
     */
    public int[] LIS (int[] arr) {
        if (arr.length <= 1 || arr == null)
			return arr;
		// 序列
		int[] end = new int[arr.length];
		// 最长子序列的长度len
		int[] indlen = new int[arr.length];
		end[0] = arr[0];
		// 序列的长度
		int len = 1;
		indlen[0] = len;
		for (int i = 1; i < arr.length; i++) {
			if (end[(len - 1)] < arr[i]) {
				// 如果大于就放在end后
				end[len++] = arr[i];
				indlen[i] = len;
			} else if (end[len - 1] == arr[i]) {
				indlen[i] = len;
			} else {
				// 替换第一个大于元素位置
				int index = findFirstIndex(end, len, arr[i]);
				end[index] = arr[i];
				indlen[i] = (index + 1);
			}
		}

		int[] res = new int[len];
		for (int i = arr.length - 1; i >= 0; i--) {
			if (indlen[i] == len) {
				res[--len] = arr[i];
			}
		}
		return res;
	}

	private int findFirstIndex(int[] end, int len, int key) {
		int left = 0;
		int right = len - 1;
		while (left <= right) {
			int mid = (left + right) >> 1;
			if (end[mid] < key) {
				left = mid + 1;
			} else {
				right = mid - 1;
			}
		}
		return left;
	}
}
全部评论

相关推荐

牛客765689665号:没有实习是硬伤,央国企看学历
点赞 评论 收藏
分享
浪子陪都:简历最优秀的地方放到了后面,国奖,校级奖学金这些是最亮眼的。说明你跟同级别的学生不一样。 建议台灯这个,PCB布局布线这个词汇不专业,业内是PCB Layout,第二,单片机的板子一般不用考虑SI,PI 都是低速信号,只要遵循3W原则就好了。 单片机的项目太low了,技能这块,你要看一下BOSS直聘的招聘要求,按照别人的要求写,一些关键词可以增加你简历被检索到的概率。 主修课程不用写,这个没有人去关注的。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务