将向量之间的数字放在另一个向量之间<vector>>如果两个数字的差值为 1

Put numbers from vector to vector<vector>> if two number's difference is 1

本文关键字:gt 数字 向量 之间 两个 vector 另一个 lt 如果      更新时间:2023-10-16

我对这个代码片段有问题,我无法意识到我做错了什么。

错误输出如下所示:

/storage/emulated/0/Documents/feladat.cpp:18:7: warning: expression result unused [-Wunused-value]
b[i, j] = b[a[i + 1], a[i]];
^
/storage/emulated/0/Documents/feladat.cpp:19:9: error: invalid operands to binary expression ('std::__ndk1::ostream' (aka 'basic_ostream<char>') and 'vector<vector<int> >')
cout<<b;
~~~~^ ~
/data/data/ru.iiec.cxxdroid/files/bin/../lib/gcc/arm-linux-androideabi/4.9.x/../../../../include/c++/4.9.x/ostream:218:20: note: candidate function not viable: no known conversion from 'vector<vector<int> >' to 'const void *' for 1st argument; take the address of the argument with &
basic_ostream& operator<<(const void* __p);

它继续在 (( 中的不同类型

这将是一个程序,如果两个数字的差1,则使对进入b向量。 这是我的代码:

#include <iostream>
#include <vector>
using namespace std;
int main()
{
vector<int> a = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
vector<vector<int>> b;
b.reserve(10);
int i = 0;
int j = 1;
for (i < a.size(); i++;)
{
for (j <= a.size(); j++;)
{
if (a[i + 1] - a[i] == 1)
{
b[i, j] = b[a[i + 1], a[i]];
cout << b;
}
}
}
return 0;
}

给定的代码片段中有 4 个问题:

  1. 这不是您为 2D 数组编制索引的方式:b[i, j].您按b[i][j]索引它。否则,您将使用逗号运算符来计算单个索引(b[i, j]等效于b[j](。
  2. for循环的形式是for (initialization;comparison;increment)。某些部分可以为空,但分号必须存在。因此,for (i < a.size(); i++;)应该是for (;i < a.size(); i++;)的,或者,或者for (int i = 0; i < a.size(); i++;)。循环也是如此j
  3. 由于索引(可能未分配(空间而导致的未定义行为b.如果你想为每个向量创建 10 个元素,所以你可以使用operator[],考虑通过vector<vector<int>> b (10, vector<int> (10));分配所有这些元素(或者,或者 (vector<vector<int>> b (a.size (), vector<int> (a.size ()));( 而不是使用reserve。 应使用reserve来防止由于多个push_back而多次重新分配。

    注意,这种变化会使循环for (;j <= a.size(); j++;)索引向量的范围无效,因为它会经过[1, 10]的值,而向量将包含有效的索引[0, 9]。您可以更改循环条件或索引(例如:b[i][j-1] = b[a[i + 1]-1][a[i]-1];(。

  4. std::vector没有定义
  5. 可用于打印的operator<<。您需要决定如何打印vector,然后定义实现此类打印的函数。