Вывод вектора списков в C ++

0

У меня возникли проблемы с выдачей моего вектора списков:

class index_table {

public:
    index_table() { table.resize(128);}
    void insert(string &, int );

private:
    class entry
    {
        public:
        string word;
        vector <int> line;
    };

    vector< list <entry> > table;
};

Я получил его так, чтобы он заполнил:

int main ()
{
index_table table;
string word,
int num = 5; //this is going to a random number. 5 is a temp. place holder.

while (cin >> word)
    table.insert(word, num);

}

но как его вывести? Я пробовал много разных подходов, но многие из них дают мне ошибки.
Нужно ли мне перегружать оператора? Я не совсем уверен, как смогу это сделать.

Теги:
io
vector
stdvector
stdlist

2 ответа

3
Лучший ответ

Предполагая, что у вас действительно есть причина использовать std::vector< std::list<entry> >, то на основе данной структуры печать слов может выглядеть так:

class index_table {
public:
    void print() {
        for (size_t i = 0; i < table.size(); ++i) {
            std::list<entry>::iterator li;
            for (li = table[i].begin(); li != table[i].end(); ++li)
                std::cout << li->word << " ";
        }
    }
    ...

private:
    std::vector< std::list<entry> > table;
    ...
};
1

Если ваш компилятор поддерживает С++ 11, вы можете использовать две циклы, основанные на диапазонах. Посмотрите в функции void index_table::dump().

// Output function
void index_table::dump() {
    for (list<entry> &le : table) {
        for (entry &e : le) {
            e.dump();
        }
    }
}

Я также создал функцию dump() в классе ввода, которая выводит содержимое двух переменных, которые теперь становятся закрытыми.

class index_table {
    public:
    index_table() {
        table.resize(128);
    }

    void insert (int,string&,int);
    void dump();

    private:
    class entry {
        private:
        string word;
        int value;

        public:
        entry (string word, int value) {
            this->word = word;
            this->value = value;
        }

        void dump() {
            cout << "Word/value is: " << word << "/" << value << endl;
        }
    };

    vector< list <entry> > table;
};

void index_table::insert(int c, string &key, int value) {
//void index_table::insert(string &key, int value) {
    entry obj(key, value);

    table[c].push_back(obj);
}

// Output function
void index_table::dump() {
    for (list<entry> &le : table) {
        for (entry &e : le) {
            e.dump();
        }
    }
}

int main (int argc, char **argv) {
    index_table mytable;

    string a = "String 0-A";
    string b = "String 0-B";
    string c = "String 1-A";
    string d = "String 1-B";
    string e = "String 6-A";
    string f = "String 6-B";

    mytable.insert(0, a, 1);
    mytable.insert(0, b, 2);
    mytable.insert(1, c, 3);
    mytable.insert(1, d, 4);
    mytable.insert(6, e, 3);
    mytable.insert(6, f, 4);

    mytable.dump();
}

Выходы программы:

Word/value is: String 0-A/1
Word/value is: String 0-B/2
Word/value is: String 1-A/3
Word/value is: String 1-B/4
Word/value is: String 6-A/3
Word/value is: String 6-B/4

PS: Я также немного изменил свой код, чтобы сделать его легче для моего теста.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню