C++ 使用迭代器和反向迭代器打印向量元素有更好的方法吗?
我有一个程序,可以创建一个C++ 使用迭代器和反向迭代器打印向量元素有更好的方法吗?,c++,algorithm,c++11,iterator,stdvector,C++,Algorithm,C++11,Iterator,Stdvector,我有一个程序,可以创建一个std::vector,并使用push_back()将给定的值添加到该程序中。预期的输出是使用迭代器和反向迭代器以默认顺序和反向顺序打印向量值。输出是绝对正确的,但我只是想知道是否有更好的方法:- #include <iostream> #include <vector> using namespace std; vector<int> myvector; int i; int main
std::vector
,并使用push_back()
将给定的值添加到该程序中。预期的输出是使用迭代器和反向迭代器以默认顺序和反向顺序打印向量值。输出是绝对正确的,但我只是想知道是否有更好的方法:-
#include <iostream>
#include <vector>
using namespace std;
vector<int> myvector;
int i;
int main()
{
int n;
cin>>n;
int input;
for (i = 0; i < n; i++)
{
cin >> input;
myvector.push_back(input);
}
for (int i = 0; i < n; i++)
{
cout<<" "<<myvector[i]; //prints user vector input
}
cout<<endl;
typedef vector<int>::iterator iter_type;
iter_type from (myvector.begin());
iter_type until (myvector.end());
reverse_iterator<iter_type> rev_until (from);
reverse_iterator<iter_type> rev_from (until);
while (rev_from != rev_until)
cout << ' ' << *rev_from++; //prints reversed vector
return 0;
}
#包括
#包括
使用名称空间std;
向量myvector;
int i;
int main()
{
int n;
cin>>n;
int输入;
对于(i=0;i>输入;
myvector.push_back(输入);
}
对于(int i=0;i
#include <iostream>
#include <vector>
int main()
{
int n; std::cin >> n;
std::vector<int> g1(n); // change here
for (auto iter = g1.begin(); iter != g1.end(); ++iter) std::cin >> *iter; // change here
for (auto iter = g1.cbegin(); iter != g1.cend(); ++iter) std::cout << *iter << " "; std::cout << "\n";
for (auto iter = g1.crbegin(); iter != g1.crend(); ++iter) std::cout << *iter << " ";
return 0;
}
备选方案-1
用于
输入和打印(通常)向量的元素,并使用
函数,以及
,反向打印向量的元素
#include <algorithm>
#include <iostream>
#include <vector>
int main()
{
int n; std::cin >> n;
std::vector<int> myvector(n);
for (int& element : myvector) std::cin >> element;
for (const int element : myvector) std::cout << element << " "; std::cout << std::endl;
std::for_each(myvector.crbegin(), myvector.crend(), [](const int element) { std::cout << element << " "; }); //prints reversed vector
return 0;
}
旁注:
不要使用命名空间std;
,()
#include <iostream>
#include <vector>
int main()
{
int n; std::cin >> n;
std::vector<int> g1(n); // change here
for (auto iter = g1.begin(); iter != g1.end(); ++iter) std::cin >> *iter; // change here
for (auto iter = g1.cbegin(); iter != g1.cend(); ++iter) std::cout << *iter << " "; std::cout << "\n";
for (auto iter = g1.crbegin(); iter != g1.crend(); ++iter) std::cout << *iter << " ";
return 0;
}
备选方案-1
用于
输入和打印(通常)向量的元素,并使用
函数,以及
,反向打印向量的元素
#include <algorithm>
#include <iostream>
#include <vector>
int main()
{
int n; std::cin >> n;
std::vector<int> myvector(n);
for (int& element : myvector) std::cin >> element;
for (const int element : myvector) std::cout << element << " "; std::cout << std::endl;
std::for_each(myvector.crbegin(), myvector.crend(), [](const int element) { std::cout << element << " "; }); //prints reversed vector
return 0;
}
旁注:
如果你能添加一些解释,你的答案肯定会更好!不管怎样,做得很好!这看起来好多了,只是想弄清楚push_back()的实现,哈哈,brb fellasy如果你能添加一些解释,你的答案肯定会更好!不管怎样,做得很好!这看起来好多了,只是想弄清楚push_back()在这里实现lol,brb伙计们