私はユーザーにベクトルに入れた数字を入力するように依頼しようとしていますが、関数呼び出しを使用して数字を計算していますが、なぜこれが機能しないのですか?私は最初の数だけを計算することができます。
template <typename T>
void write_vector(const vector<T>& V)
{
cout << "The numbers in the vector are: " << endl;
for(int i=0; i < V.size(); i++)
cout << V[i] << " ";
}
int main()
{
int input;
vector<int> V;
cout << "Enter your numbers to be evaluated: " << endl;
cin >> input;
V.Push_back(input);
write_vector(V);
return 0;
}
そのままで、あなたはただ一つの整数を読み込んでそれをあなたのベクトルにプッシュしているだけです。おそらくいくつかの整数を保存したいので、ループが必要です。たとえば、交換
cin >> input;
V.Push_back(input);
と
while (cin >> input)
V.Push_back(input);
これは、グラブへの入力がある限り、cinからintを継続的にプルします。 cinはEOFを見つけるか、整数以外の値を入力しようとするまでループを継続します。代わりにセンチネル値を使用することもできます。
while ((cin >> input) && input != 9999)
V.Push_back(input);
9999(またはcinを無効にする他の状態)を入力しようとするまで読み取りを行い、その時点でループが終了します。
他の回答では、特定の番号を許可しないようにするか、入力を終了するために非数値を入力するようにユーザーに指示します。おそらく、より良い解決策は、std::getline()
を使用してlineの入力を読み取り、_std::istringstream
_を使用してその行からベクトルにすべての数値を読み取ることです。
_#include <iostream>
#include <sstream>
#include <vector>
int main(int argc, char** argv) {
std::string line;
int number;
std::vector<int> numbers;
std::cout << "Enter numbers separated by spaces: ";
std::getline(std::cin, line);
std::istringstream stream(line);
while (stream >> number)
numbers.Push_back(number);
write_vector(numbers);
}
_
また、write_vector()
実装は、要素を_std::ostream_iterator
_から_std::cout
_にコピーするstd::copy()
アルゴリズムのより慣用的な呼び出しに置き換えることができます。
_#include <algorithm>
#include <iterator>
template<class T>
void write_vector(const std::vector<T>& vector) {
std::cout << "Numbers you entered: ";
std::copy(vector.begin(), vector.end(),
std::ostream_iterator<T>(std::cout, " "));
std::cout << '\n';
}
_
std::copy()
といくつかの便利なイテレータを使用して、明示的なループなしで値をベクトルに取得することもできます。
_std::copy(std::istream_iterator<int>(stream),
std::istream_iterator<int>(),
std::back_inserter(numbers));
_
しかし、それはおそらくやり過ぎです。
そのためにはループが必要です。これを行う:
while (cin >> input) //enter any non-integer to end the loop!
{
V.Push_back(input);
}
または、この慣用的なバージョンを使用します。
#include <iterator> //for std::istream_iterator
std::istream_iterator<int> begin(std::cin), end;
std::vector<int> v(begin, end);
write_vector(v);
write_vector
を次のように改善することもできます。
#include <algorithm> //for std::copy
template <typename T>
void write_vector(const vector<T>& v)
{
cout << "The numbers in the vector are: " << endl;
std::copy(v.begin(), v.end(), std::ostream_iterator<int>(std::cout, " "));
}
次の2つのオプションがあります。
ベクトルのサイズがわかっている場合(あなたの場合/例ではそれを知っているようです):
vector<int> V(size)
for(int i =0;i<size;i++){
cin>>V[i];
}
そうしないと、あなたのプログラムフローでそれを取得できない場合:
int helper;
while(cin>>helper){
V.Push_back(helper);
}
One-liner読み取りfixed数値の量をベクトル(C++ 11):
#include <algorithm>
#include <iterator>
#include <iostream>
#include <vector>
#include <cstddef>
int main()
{
const std::size_t LIMIT{5};
std::vector<int> collection;
std::generate_n(std::back_inserter(collection), LIMIT,
[]()
{
return *(std::istream_iterator<int>(std::cin));
}
);
return 0;
}
2番目の整数が必要です。
int i,n;
vector<int> V;
cout << "Enter the amount of numbers you want to evaluate: ";
cin >> i;
cout << "Enter your numbers to be evaluated: " << endl;
while (V.size() < i && cin >> n){
V.Push_back(n);
}
write_vector(V);
return 0;
cinはスペースで区切られているので、cin "1 2 3 4 5"を1つの整数にしようとすると、整数に1を割り当てるだけになります。より良いオプションは、入力とPush_backをループでラップすることです。センチネル値をテストし、そのセンチネル値で書き込み関数を呼び出します。といった
int input;
cout << "Enter your numbers to be evaluated, and 10000 to quit: " << endl;
while(input != 10000) {
cin >> input;
V.Push_back(input);
}
write_vector(V);
for loopの助けを借りてこれを行うことができます
->ユーザーから実行時に尋ねる(入力したい入力数)、配列のように扱う。
int main() {
int sizz,input;
std::vector<int> vc1;
cout<< "How many Numbers you want to enter : ";
cin >> sizz;
cout << "Input Data : " << endl;
for (int i = 0; i < sizz; i++) {//for taking input form the user
cin >> input;
vc1.Push_back(input);
}
cout << "print data of vector : " << endl;
for (int i = 0; i < sizz; i++) {
cout << vc1[i] << endl;
}
}
#include<iostream>
#include<vector>
#include<string>
using namespace std;
int main()
{
vector<string>V;
int num;
cin>>num;
string input;
while (cin>>input && num != 0) //enter any non-integer to end the loop!
{
//cin>>input;
V.Push_back(input);
num--;
if(num==0)
{
vector<string>::iterator it;
for(it=V.begin();it!=V.end();it++)
cout<<*it<<endl;
};
}
return 0;
};
1つだけでなく、もっと多くの数字を読みたいと思うでしょう。これには、ループが必要です
int main()
{
int input = 0;
while(input != -1){
vector<int> V;
cout << "Enter your numbers to be evaluated: " << endl;
cin >> input;
V.Push_back(input);
write_vector(V);
}
return 0;
}
このバージョンでは、「終了信号」であるため、数値-1を追加することはできません。数字を入力するのは好きなだけで、-1を入力すると打ち切られます。
#include<iostream>
#include<vector>
#include<sstream>
using namespace std;
int main()
{
vector<string> v;
string line,t;
getline(cin,line);
istringstream iss(line);
while(iss>>t)
v.Push_back(t);
vector<string>::iterator it;
for(it=v.begin();it!=v.end();it++)
cout<<*it<<endl;
return 0;
}
#include<bits/stdc++.h>
using namespace std;
int main()
{
int x,n;
cin>>x;
vector<int> v;
cout<<"Enter numbers:\n";
for(int i=0;i<x;i++)
{
cin>>n;
v.Push_back(n);
}
//displaying vector contents
for(int p : v)
cout<<p<<" ";
}
ベクトルで入力を取得する簡単な方法。
この場合、while
ループは次のようになります
int i = 0;
int a = 0;
while (i < n){
cin >> a;
V.Push_back(a);
++i;
}
V
の最初のsize()
は0になりますが、int nには初期化しないため、ランダムな値が含まれます。
V.size() < n
はおそらくfalseです。
愚かな私は_"Enter the amount of numbers you want to evaluate: "
_を見逃した
そのときにV.size()
より小さいn
を入力すると、ループは終了します。
別の変数を追加するだけです。
int temp;
while (cin >> temp && V.size() < n){
V.Push_back(temp);
}
入力を取得してベクトルのサイズを指定すると、より簡単になります。
int main()
{
int input,n;
vector<int> V;
cout<<"Enter the number of inputs: ";
cin>>n;
cout << "Enter your numbers to be evaluated: " << endl;
for(int i=0;i<n;i++){
cin >> input;
V.Push_back(input);
}
write_vector(V);
return 0;
}