0

我有一个数字网格的大文件(50x11k)。我要做的就是将这些值放入一个向量中,以便我可以同时访问不同行的值。我每次都会遇到段错误(我什至不能在 while 循环之前做一个 cout)。有人看到这个问题吗?

如果有更简单的方法可以做到这一点,请告诉我。它是一个大文件,我需要能够将一行的值与另一行的值进行比较,因此简单的 getline 不起作用,有没有办法跳过文件而不是“抓住”行,而只是“检查”行,以便我以后可以通过输入该数字返回检查同一行?像看一个大数组一样的文件?我想同时查看第三行和该行中的 5 个字符,同时查看第 56 行和第 9 个字符,类似的东西。

#include <stdlib.h>
#include <iostream>
#include <fstream>
#include <string>
#include <vector>

using namespace std;

//int g_Max = 0;

int main() {

    vector<vector<string> > grid;

    ifstream in("grid.txt");
    int row = 0;
    int column = 0;
    string c;

    if (!in) {
        cout << "NO!";
    }

    while (!in.eof()) {
        c = in.get();
        if ( c.compare("\n") == 0) {
            row++;
            column = 0;
        }
        else {
            c = grid[column][row];
            cout << grid[column][row];
            column++;
        }
    }

    return 0;
}
4

2 回答 2

2
    vector<vector<string> > grid;

这声明了一个空向量,没有元素。

        c = grid[column][row];

这会访问向量的元素,但没有元素。

如果您将其更改为使用vector::at()而不是vector::operator[]这样:

        c = grid.at(column).at(row);

然后你会得到异常,告诉你你正在访问超出范围。

您需要先用元素填充向量,然后才能访问它们。一种方法是预先用正确数量的元素声明它:

    vector<vector<string> > grid(11000, std::vector<string>(50));

您可能还想修复您的 IO 循环,测试!in.eof()通常是错误的。为什么不一次读取一行并将行拆分,而不是读取单个字符?

while (getline(in, c))
于 2012-10-18T00:19:02.933 回答
0

如果您只需要一次访问所有行,为什么不将其声明为,std::vector<std::string>并且每一行都是string??

std::string s;
std::vector<std::string> lines;
while( std::getline(in, s) ) lines.push_back( s );
std::cout << "File contain " << lines.size() << " line" << std::endl;
std::cout << "Char at [1][2] is " << lines[1][2] << std::endl; // assume [1][2] is valid!
于 2012-10-18T00:30:11.693 回答