我正在阅读一个包含句子列表的文件,我需要阅读每个单词并尝试找出这个单词在哪个行号中。文件包含:
I am for truth
no matter who tells it,
I am for justice,
no matter who it is for or against
Malcom X
我希望输出采用这种形式:
against 4
matter 4
am 1, 3
no 2, 4
for 1, 3, 4
or 4
I 1, 3
tells 2
is 4
truth 1
it 2, 4
who 2,4
justice 3
X 5
Malcolm 5
我正在使用二叉搜索树,这是我的代码:
int main(int argc, char *argv[]) {
fstream infile ;
BSTFCI <string>* bst = new BSTFCI<string>();
string word;
string line;
infile.open("test.txt" , ios::in);
if(infile.fail())
{
cout<<"Error Opening file"<<endl;
return 0;
}
while(!infile.eof())
{
infile>>word;
for(int i=0 ; i<word.size();i++)
{
if(ispunct(word[i]))
word.erase(i,1);
}
cout<<count<<endl;
if(!bst->search(word))
{
cout<<word<<endl;
bst->insert(word);
cout<<"add"<<endl;
}
else
{
cout<<word<<endl;
cout<<"exist"<<endl;
}
}
infile.close();
return 0;
}