gpt4 book ai didi

c++ - while(fin>>a) 或 while(fin.eof()) 将不起作用。在第一种情况下,fin 流变量一直将文件中的最后一个字符作为输入

转载 作者:行者123 更新时间:2023-11-27 22:49:14 32 4
gpt4 key购买 nike

while(fin >> a)

while(fin.eof())

不会工作。在第一种情况下,fin 流变量一直将文件中的最后一个字符作为输入。

我的输入文件是这样的:

ab5c71,lj4j6v7;
sd9vg0,kj9ref9,fjuwe;

这是我的代码:

[![int main()
{
int count = 0, col = 0, row = 0;
ifstream fin;
fin.open("Text.txt");
char a;
//count number of rows and cols
while (fin >> a)
{
while (a != ',')//marks end of one word in a sentence
{
if (a >= '0'&&a <= '9')//sees if the input is a number
{
count++;
}
if (a == ';')
{
if (count > 0)
{
col++;
}
if (col > 0)
{
row++;
count = 0;
col = 0;
}
}
fin >> a;
}
if (count > 0)
{
col++;
}
count = 0;
}
cout << row << " " << col;
return 0;
}][1]][1]

嗯,这不是完整的代码。代码的实际期望输出是读取文件并输出包含所有数字的矩阵,一个单词中的数字(即逗号之前)应该是一个完整的编号并组成一列,每行以分号结尾,分号表示一行结束。一个词可能不包含任何数字,在这种情况下,矩阵中没有输入,也可能整个行/句子由这样的词组成,在这种情况下,不添加任何行。到目前为止,我编写的代码仅计算需要多少行和多少列。假设所有行都包含相等的列。

所附示例文件的所需输出将是矩阵=[57,467 ; 90,99](逗号和分号不应该是矩阵的一部分,只是添加它们以标记一个元素(逗号)和行(分号)的结尾)

最佳答案

这里的问题(几乎可以肯定)不是你的 while (fin>>a),而是循环内的 fin >> a;,它不测试结果,因此如果在文件末尾调用它,您将无限期地在循环内继续。

iostreams 在做你在这里想做的事情时并不是特别有用。特别是,如果我们可以让流读取到下一个逗号或分号(以先到者为准)并告诉我们哪一个结束了特定的读取,那将是非常好的nice。这会让我们捕获下一个“字段”,查看其内容,并做出相应的 react 。

如果没有,我们有一些可用的替代方案。一种是读取完整的“记录”(分号之前的所有内容),将其拆分为字段,然后查看每个字段:

std::string record;

while (std::getline(fin, record)) {
std::istringstream buffer(record);
std::string field;
while (std::getline(buffer, field))
if (std::any_of(field.begin(), field.end(),
[](unsigned char ch) { return isdigit(ch); })
{
++col;
}
// when we get here, we've looked at all the fields of the current record.
}

关于c++ - while(fin>>a) 或 while(fin.eof()) 将不起作用。在第一种情况下,fin 流变量一直将文件中的最后一个字符作为输入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39297402/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com