计算文件行数的最简洁方法是什么? 我需要此信息来创建/初始化矩阵数据结构。
稍后我必须再次遍历文件并将信息存储在矩阵中。
更新:基于 Dave Gamble 的。但为什么这不能编译? 请注意,该文件可能非常大。所以我尽量避免使用容器 以节省内存。
#include <iostream>
#include <vector>
#include <fstream>
#include <sstream>
using namespace std;
int main ( int arg_count, char *arg_vec[] ) {
if (arg_count !=2 ) {
cerr << "expected one argument" << endl;
return EXIT_FAILURE;
}
string line;
ifstream myfile (arg_vec[1]);
FILE *f=fopen(myfile,"rb");
int c=0,b;
while ((b=fgetc(f))!=EOF) c+=(b==10)?1:0;
fseek(f,0,SEEK_SET);
return 0;
}
最佳答案
我认为这可能会...
std::ifstream file(f);
int n = std::count(std::istreambuf_iterator<char>(file), std::istreambuf_iterator<char>(), '\n') + 1;
关于c++ - 用 C++ 计算文件行数的最简洁方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1225589/