从文本文件中读取单词C ++(奇怪的字符)

时间:2013-03-26 22:55:26

标签: c++ file text

firstword secondword thirdword fourthword ...

我的文本文件包含200个单词,就像这个顺序一样,我想阅读并将它们复制到2D固定长度的数组中,没有奇怪的字符。我无法使用这段代码执行此操作:

ifstream FRUITS;
FRUITS.open("FRUITS.TXT");


    if(FRUITS.is_open())
    {
        char fruits1[200][LEN];
        int c;

        for(c = 0; c < 200; c++)
        {
            char* word;
            word = new char[LEN];

            FRUITS >> word;

            for(int i = 0; i < LEN; i++)
            {
                fruits1[c][i] = word[i];
            }
        }
    }

我该怎么做?

2 个答案:

答案 0 :(得分:0)

您需要在单词的末尾添加'\0',以便在单词的长度小于LEN时不会有任何奇怪的字符。

但是我建议使用字符串向量来完成这项工作。

#include <iostream>
#include <fstream>
#include <vector>
#include <string>

using namespace std;
int main()
{
    fstream file;
    vector<string> v;
    file.open("FRUITS.txt");
    string tmp;
    while(!file.eof())
    {
        file >> tmp;
        v.push_back(tmp);
    }
    for(vector<string>::iterator i=v.begin(); i!=v.end(); i++)
    {
        cout << *i << endl;
    }
    file.close();
    return 0;
}

答案 1 :(得分:0)

想一想:

FRUITS >> fruits1[c];

但您必须确保LEN足以容纳每个单词中的所有char加上'\0'

不要担心"=+½$#".当您执行cout << fruits1[c];这样的事情时,他们就不会被打印出来。