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

最长上升子序列(三)

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;
	}
}
全部评论

相关推荐

28小凳也想实习:项目不用一个业务一个轮子吗,刷牛客好多人说要一业务一轮子
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务