【发布时间】:2019-09-08 20:55:53
【问题描述】:
我在练习编写合并两个列表的算法时遇到了一些问题。
#include<iostream>
#include<vector>
using namespace std;
int main(){
vector<int> list1,list2;
int tmp;
cin>>tmp;
while(tmp!=-1){
list1.push_back(tmp);
cin>>tmp;
}
cin>>tmp;
while(tmp!=-1){
list2.push_back(tmp);
cin>>tmp;
}
vector<int> list3(list1.size()+list2.size());
vector<int>::iterator iter1=list1.begin();
vector<int>::iterator iter2=list2.begin();
while(iter1!=list1.end()&&iter2!=list2.end()){
if(*iter1<*iter2){
list3.push_back(*iter1);
iter1++;
}
else{
list3.push_back(*iter2);
iter2++;
}
}
while(iter1!=list1.end()){
list3.push_back(*iter1);
iter1++;
}
while(iter2!=list2.end()){
list3.push_back(*iter2);
iter2++;
}
if(list3.size()==0) cout<<"NULL";
for(int i=0;i<list3.size();i++){
cout<<list3[i];
if(i!=list3.size()-1){
cout<<" ";
}
}
return 0;
}
控制台输入:
1 3 5 -1
2 4 6 8 10 -1
预期的输出结果: 1 2 3 4 5 6 8 10
实际输出结果: 0 0 0 0 0 0 0 0 1 2 3 4 5 6 8 10
【问题讨论】:
-
那么在使用调试器逐行执行代码时,您观察到了什么?
-
像这样构造向量向量
list3(list1.size()+list2.size());用给定大小的零填充它,考虑将此行更改为 vector list3; -
考虑阅读constructor of
std::vector和std::vector::reserve的文档。他们不做同样的事情,而且看起来你想使用std::vector::reserve。
标签: c++ algorithm list data-structures