Сделал функцию для печати вектора с помощью интеграторов. Функция является частью программы, предназначенной для копирования вектора строк в другой вектор строк. Исходная функция была простым циклом for с использованием функции-члена .at (), и это сработало. Итак, я не уверен, что с этим не так. Код:
#include <string>
#include <string>
#include <fstream>
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
void print(vector<string> &v);
int main() {
ifstream inFS;
inFS.open("sentence.txt");
vector<string> wordList; vector<string> newVect;
string s;
while (inFS >> s) {
wordList.push_back(s);
}
copy(wordList.begin(), wordList.end(), newVect.begin());
print(wordList);
print(newVect);
}
void print(vector<string> &v) {
for (vector<string>::iterator i = v.begin(); i != v.end(); i++) {
cout << *i << " ";
}
cout << endl;
}
Выход:
C:\Users\westt\Documents\PROJECT>a.exe
C:\Users\westt\Documents\PROJECT>
Попробуйте это простое изменение, чтобы инициализировать newVect. Как отмечалось в комментарии, вы также можете resize () newVect
#include <string>
#include <string>
#include <fstream>
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
void print(vector<string> &v);
int main() {
ifstream inFS;
inFS.open("sentence.txt");
vector<string> wordList;
string s;
while (inFS >> s) {
wordList.push_back(s);
}
vector<string> newVect(wordList);
print(wordList);
print(newVect);
}
void print(vector<string> &v) {
for (vector<string>::iterator i = v.begin(); i != v.end(); i++) {
cout << *i << " ";
}
cout << endl;
}
Отлично, спасибо, сработало. Что с этим не так?
Копия оказалась не той. Правильное использование неинтуитивно, stackoverflow.com/questions/1128535/stl-vector-reserve-and-c opy
Ой, простите. Я только что сделал. Спасибо еще раз.
Перед
copy
вам нужно убедиться, что вnewVect
достаточно элементов. ДобавьтеnewVect.resize(wordList.size());
передcopy
.