首页 > 编程语言 > 详细

最长连续递增序列-贪心算法-基于Go

时间:2021-04-08 15:18:50      阅读:21      评论:0      收藏:0      [点我收藏+]

给定一个未经排序的整数数组,找到最长且连续递增的子序列,并返回该序列的长度。

如:
[1,2,3,2,3,4,3,4,5,6,7]
返回5.

  • 贪心算法
func findLength(nums []int)int{
	var start = 0
	var maxLength = 0
	for i:=1;i<len(nums);i++{
		if nums[i]<=nums[i-1]{
			start = i
		}
		maxLength = int(math.Max(float64(maxLength),
							float64(i-start+1)))
	}

	return maxLength
}
  • 双指针
func findLength2(nums []int)int{
	var low = 0
	var high = 1
	var n = len(nums)
	var maxLength = 0
	for low<n && high<n{
		if nums[high]<=nums[high-1]{
			low = high
		}
		maxLength = int(math.Max(float64(high-low+1),
								float64(maxLength)))
		high++
	}

	return maxLength
}

最长连续递增序列-贪心算法-基于Go

原文:https://www.cnblogs.com/pangqianjin/p/14631599.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!