我一直在编写一个程序,该程序以两个不同的"向量"从用户那里获取输入,并在按下回车键时停止。代码如下
#include <iostream>
#include <vector>
#include <string>
using namespace std;
int main()
{
vector<string> a,c;
string b;
int m=0;//,words = 0;
do
{
cin>>a[m];
m++;
}
while(cin.get()!= 'n');
int n=0;
do
{
cin>>c[n];
n++;
}
while(cin.get() != 'n');
int mida=a.size()/2, midc=c.size()/2;
int count;
int i,j;
for(i=0;i<n;i++)
for(j=0;j<m;j++)
{
if(a[i] == c[j])
count++;
}
if(count >= mida || count >= midc)
cout<<"similar"<<endl;
else
cout<<"dissimilar"<<endl;
return 0;
}
现在的问题是,当我在输入单词后运行代码时,我需要在向量中放入一些由空格分隔的"芒果"橙色"之类的东西,但是一旦我按回车键,我就会出现分段错误。谁能告诉我可能出现什么问题。
当您创建一个 std::vector
对象时,它开始时为空,其size
将为零,并且其中的所有索引都将超出界限并导致未定义的行为(以及可能的崩溃(。
您可以使用push_back
将元素附加到向量。喜欢
std::string s;
std::cin >> s;
a.push_back(s);
虽然以上是您遇到崩溃的最可能原因,但这不是您唯一的问题。另一个是每个输入字符串可能以换行符结尾。如果你想读一整行,然后将其分成"单词",那么我建议你用std::getline
来阅读整行,然后使用std::istringstream
从行中获取单独的单词。
您还可以使用 std::istream_iterator
轻松地将字符串从输入流追加到矢量。
你可以做类似的事情
std::string line;
std::getline(std::cin, line);
std::istringstream iss(line);
a = std::vector<std::string>(std::istream_iterator<std::string>(iss),
std::string>(std::istream_iterator<std::string>());
cin>>a[m];
您正在索引超过向量a
的末尾。由于向量尚未被赋予大小,因此它甚至没有空间来分配a[0]
。
一种可能的方法是使用临时变量来获取用户输入,然后a.push_back[input]
。