如何使用C#从数字数组中找到最长连续递增子序列的长度?
LongestIncreaingSubsequence返回数组中连续子序列的整数。该方法有一个for循环,它迭代并跟踪数字。最终结果将计算Max。时间复杂度是O(N)因为每个元素都被访问一次,空间复杂度是O(1),因为我们没有使用任何存储空间。
时间复杂度-O(N)
空间复杂度-O(1)
示例 -{2,4,6,5,8}
输出-3
示例
public class Arrays{
public int longestIncreaingSubsequence(int[] nums){
if (nums == null ||nums.Length== 0){
return -1;
}
int res = 0, count = 0;
for (int i = 0; i < nums.Count(); i++){
if (i == 0 || nums[i] > nums[i - 1]){
count++;
res = Math.Max(res, count);
}
else{
count = 1;
}
}
return res;
}
}
static void Main(string[] args){
int[] nums = { 1, 3, 5, 4, 7 };
Console.WriteLine(s.longestIncreaingSubsequence(nums));
}输出结果3
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短