获取索引和元素-向量问题

Obtaining indices and elements - vector problem

本文关键字:向量 问题 元素 索引 获取      更新时间:2023-10-16

我想做以下事情;我试过了,但没有成功。所以我希望有办法解决这个问题。

我有两个矢量。一个是vector<int> myvector,另一个是向量Plane(其中Plane是创建的类,存储平面参数和平面的其他属性)

例如,我会给你举一些我的例子;如果

myvector = <0, 1, 4, 6, 7, 10, 12, 13, 14, 15, 16, 17>
myvector_new = <plane0, plane1, plane4, plane6, plane7, plane10, plane12, plane13, plane15, plane16, plane17>

(以上两个矢量的大小相同。)

我想修改这2个现有的矢量或创建2个新的矢量,

myvector_new = <0,1,-1,-1, 4,-1, 6, 7,-1,-1, 10,-1, 12, 13, 14, 15, 16, 17>
myplane_new = <plane0, plane1, null, null,plane4,null,plane6, plane7,null,null, plane10,…., plane17>

(也就是说,如果我用另一种方式说我需要什么;首先,我想要一个大小等于myvector的最大元素的向量。然后,如果它是有效值,我可以直接使用这个向量的索引来获取我的其他程序的内部元素值。但是,新向量必须只包含上面的有效值(即已经存在的值)。所以,我希望放一个负值来表示我将要推回或插入的其他值。同时,我想修改我的第二个向量myplane,只包括以前存在的类Plane的有效值,也包含无效值(如空平面或空对象)。

所以,我用向量插入函数试过这个,但我做不到。然后我尝试创建新的向量,如下所示;

//some codes above to create myvector and myplane
Vector<int> myvector_new;
Vector<Plane> myplane_new;
 for(int k=0; k<myvector.size(); k++){        
      if (myvector.at(k)==k){
          myvector_new.push_back(k);
          myplane_new.push_back(myplane.at(k))
      }    
      else{
          for(int m=k; m<myvector.at(k); m++){
              myvector_new.push_back(-1);
              myplane_new.push_back(null); 
          }       
          myvector_new.push_back(myvector.at(k));
          myplane_new.push_back(myplane.at(k)); 
          }
      }
When I cheked myvector_new (I checked only this sofar) simply as follows;
  for(int m=0;m<myplane_new.size();m++){
          cout<<myplane_new[m]<<" ";
          }

我得到了以下结果。请任何人帮我修改代码。

0 1-1-1 4-1-1-1 6-1-1-1 7-1-1-1-1-1 10-1-1-1 1-1-1-1 12-1-1-1-1-1-1-1 13-1-1-1-1 14-1-1-1-1-1-1-1-1 17

但是,这是错误的。如果有人能帮助我修改代码以获得所需的结果,我们将不胜感激。

我不确定你的代码出了什么问题,但似乎有一种更容易的方法来编码你的算法:

// determine appropriate size of result
vector<int>::size_type newsize = myvector.back()+1;
// or, if not sorted:
// vector<int>::size_type newsize = std::max_element(myvector.begin(), myvector.end());
// Create new vectors of the appropriate length
vector<int> myvector_new(newsize, -1);
vector<Plane> myplane_new(newsize);
// Overwrite elements that aren't null
for(vector<int>::size_type i = 0; i < myvector.size(); i++) {
  myvector_new[myvector[i]] = myvector[i];
  myplane_new[myvector[i]] = myplane[i];
}

快速代码审查告诉我这是罪魁祸首:

for(int m=k; m<myvector.at(k); m++){

我想你想把m设置为myvector.at(k-1)(但要小心如果k是0会发生什么)。