将向量的元素与同一向量的所有元素相乘
Multiply elements of a vector with all elements of same vector
我正在尝试解决一个问题,我想将向量的元素与同一向量的所有元素相乘(也与自身相乘)。
我有一个有效的解决方案,如下所示:
for(int i=0;i<v.size();i++)
{
for(int j=0;j<v.size();j++)
{
r.insert(v[i]*v[j]);
}
}
在这里,v
是最初存储元素的向量,r
是我存储产品的向量。
我面临的问题:
这是一个 O(N^2) 算法,我想在 O(N) 时间内实现这一点。有什么办法可以做到这一点吗?谢谢。
编辑 1:
实际上,我想在通过将向量的元素与其他元素相乘而获得的数字列表中找到第 n 个最大的数字。我的方法是:
- 查找乘积并将值存储在向量中。(时间- O(N^2) )。
- 对向量进行排序。(时间 - O(N logN) )
- 通过索引访问查找第 n 个最大数字。
我想提高 N^2 的时间复杂度。
您可以做的是避免两次计算相同的值。事实上,使用您的解决方案,所有货币对都将乘以两次。如果在矩阵中显示结果值,则最好看到这一点:
input: [a, b, c]
output:
aa ba ca
ab bb cb
ac bc cc
您可以看到对角线两侧的对称性。这意味着在计算第 n 列时,您只需要计算size of input - n
值,因为其他n
已经存在于前面的列中,您可以在其中检索它们。
请注意,这对算法的复杂性没有影响。
这个问题在当前公式中无法O(n)
时间内解决,因为输出具有O(n^2)
元素。
相关文章:
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- C++:如何循环通过向量中的整数元素
- 如何在C++向量中奇数元素前面加上值-1,我在使用insert函数时遇到了问题
- 不允许在向量中添加更多元素
- 基于范围的 for 循环:迭代使用一个元素扩展的向量
- 使用并行参数向量调用元素向量的成员函数
- C++ 查找字符串中存在的元素向量
- 包含 std::threads 的元素向量
- 避免从单一元素向量转换为基元类型
- 对自定义元素向量进行排序时出现意外(至少对我来说)行为
- 如何为对元素(向量和int)配对创建unique_ptr也是unique_ptr
- 元素向量乘法 C++(代码不起作用)
- 时间和空间复杂性在二叉树的每个级别创建元素向量(NON-BST)
- 遍历结构元素向量
- 犰狳C++中的元素向量或矩阵乘法
- 为什么'std::vector<int> b{2};'创建 1 元素向量,而不是 2 元素向量?
- 可移动元素向量的大小调整是否有效?
- 唯一元素向量的c++模板函数
- 获取索引和元素-向量问题
- 定义一个生成元素向量的函数时,正确的方法是什么?