一个向量中的单调子向量的数目
Number of monotonus subvectors in one vector
我需要在向量或数组中找到一些单调的子向量或数组,这并不重要。例如,我有向量1234421257843
,这里有4个单调子向量。。。
1. 1 2 3 4 4
2. 4 4 2 1
3. 1 2 5 7 8
4. 8 4 3, and number is 4.
我试过这样的东西,但不起作用。。。
int num(std::vector<int> v){
int p(1),q(1);
for(int i(0);i<v.size()-1;i++){
if (v[i] > v[i+1] ) continue;
else if(v[i] < v[i+1]) continue;
else p++;
} return p;
}
我相信这将帮助您在一个向量中找到单调子向量的数量:
int num(const std::vector<int>& v) {
int p = 0;
for (int i = 0; i + 1 < v.size(); ) {
p += (v[i+1] >= v[i]);
for (++i; (i + 1 < v.size()) && (v[i+1] >= v[i]); ++i) {
}
if (i + 1 == v.size())
return p;
p += (v[i+1] <= v[i]);
for (++i; (i + 1 < v.size()) && (v[i+1] <= v[i]); ++i) {
}
}
return p;
}
但若你们想找到最大的单调子向量,你们不需要这个。该任务可以在DP(动态编程)的帮助下解决:您需要两个额外的向量a(n)和d(n),其中a(i)/d(i)-是在位置i处结束的最长上升/下降子向量的长度:从a[0]=1开始,如果v[i+1]>v[i]或1,则可以很容易地计算a[i+1]=a[i]+1
相关文章:
- 在C++/Linux中设置单调时钟的一些技巧
- 写入向量<向量<bool>>
- 函数向量_指针有不同的原型,我可以构建一个吗
- std::向量与传递值的动态数组
- 将值指定给向量(2D)的向量中的某个位置
- 找不到成员对象:没有名为get_event()的成员,也处理多态性和向量
- 如何使用向量的template_back函数
- 尝试通过多个向量访问变量时,向量下标超出范围
- 如何通过派生类函数更改基类中的向量
- C++从另一个类访问公共静态向量的正确方法是什么
- 如何将ampl中的集合表示为c++中的向量
- 变量没有改变?通过向量的函数调用
- 迭代时从向量和内存中删除对象
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- 如何为模板化对象创建模板向量?VS正在投掷C3203
- 计算排序向量的向量中唯一值的计数
- 矩阵向量乘法(cublasDgemv)返回零
- 一对向量构造函数:初始值设定项列表与显式构造
- 将结构向量排序为子组
- 在C++中调整向量中的索引