1

我必须在我的代码中使用这个结构:

struct Pair
{
   int x,y;
   friend bool operator==(Pair a, Pair b)
   {
     return a.x == b.x && a.y == b.y;
   }
   friend istream& operator>>(istream& is, Pair& a)
   {
     is >> a.x >> a.y;
     return is;
   }
   friend ostream& operator<<(ostream& os, Pair a)
   {
     os << '(' << a.x << ',' << a.y << ')';
     return os;
   }
};

我需要阅读一个 .txt 文件:

5 1 1 2 2 3 3 4 4 5 5
7 1 1 2 2 3 3 4 4 4 7 7 4 7 7
8 1 1 2 4 3 9 4 16 5 25 6 36 7 49 8 64

该文件中有 3 个关系,每个关系都以一个 int 开头,它是该关系中的对数,然后是许多对。然后(如果不是 eof)再次读取另一个 int 和那么多对,依此类推。

如何将这些数据读入我的结构对?

在我读完它之后,我将不得不测试数据是否是自反的,等等,但我只是在开始这个项目时遇到了麻烦。

4

1 回答 1

2

这就是我要写的。

我知道我对它的看法可能有点“高级”——但至少它应该告诉你所需的代码实际上并不多。

一点解释:

  • 使用字符串流 ( istringstream) 允许您将单行视为流。这不是绝对必要的,但如果输入不是预期的格式,可以防止事情出错。

  • friend运算符(特别是operator>>)将允许您“仅”从流中读取一对,只需:

    Pair p;
    stream >> p;
    

    现在,当我在 an 上调用算法时,这就是下面的代码隐含的作用(即,它以与我刚刚展示的完全相同的方式提取 s)。copy_nistream_iterator<Pair>Pair

using Pairs = vector<Pair>;

int main()
{
    string line;
    while (getline(cin, line))
    {
        istringstream iss(line);

        unsigned n;
        Pairs pairs;

        if (iss >> n)
            copy_n(istream_iterator<Pair>(iss), n, back_inserter(pairs));

        if (!iss)
            return 255;

        std::cout << "Read a line with " << n << " pairs (check: " << pairs.size() << ")\n";
    }
}

使用问题中的示例输入在 Coliru上查看它,打印:

Read a line with 5 pairs (check: 5)
Read a line with 7 pairs (check: 7)
Read a line with 8 pairs (check: 8)
于 2013-10-16T23:11:03.953 回答