gpt4 book ai didi

c++ - 在 C++ 中从给定的未排序整数 vector 中获取最长排序元素序列的最简单方法

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:11:31 24 4
gpt4 key购买 nike

我有一个未排序的数组,需要提取最长的已排序元素序列。例如

A = 2,4,1,7,4,5,0,8,65,4,2,34

这里0,8,65是我的目标序列

我需要跟踪这个序列开始的索引

最佳答案

您可以使用此算法在线性时间 O(N) 内完成:构建与原始大小相同的 N vector len vector ,使得 len[i] 包含元素 seq[i] 所属的最长连续上升运行的长度。

len[i] 的值可以计算如下:

len[0] = 1;
for (int i = 1 ; i != N ; i++) {
len[i] = seq[i-1] >= seq[i] ? 1 : len[i-1]+1;
}

有了len,找到max(len)元素的索引。这是你运行的最后一个元素。回溯到 len[j] == 1 以找到运行的初始元素。

seq    len
--- ---
2 1
4 2
1 1
7 2
4 1
5 2
0 1
8 2
65 3 << MAX
4 1
2 1
34 2

请注意,在算法的每个步骤中,您只需要元素 len[i-1] 来计算 len,因此您可以通过删除 vector 来优化常量空间len 的表示并保留之前的 max_lenmax_len_index

这是针对常量空间优化的算法。变量 len 代表线性空间算法的 len[i-1]

int len = 1, pos = 0, maxlen = 1, current_start = 0;
for (int i = 1 ; i < seq.size() ; i++) {
if (seq[i] > seq[i-1]) {
len++;
if (len > maxlen) {
maxlen = len;
pos = current_start;
}
} else {
len = 1;
current_start = i;
}
}

这里是 a link to this program on ideone .

关于c++ - 在 C++ 中从给定的未排序整数 vector 中获取最长排序元素序列的最简单方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12026361/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com