计算文件行数的最紧凑方法是什么?
我需要这些信息来创建/初始化矩阵数据结构。
稍后我必须再次浏览文件并将信息存储在矩阵中。
更新: 基于 Dave Gamble's。但是为什么这不能编译?
请注意,该文件可能非常大。所以我尽量避免使用容器
以节省内存。
#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;
}
最佳答案
FILE *f=fopen(filename,"rb");
int c=0,b;while ((b=fgetc(f))!=EOF) c+=(b==10)?1:0;fseek(f,0,SEEK_SET);
在 c 中回答。
那种紧凑?
关于c++ - 在 C++ 中计算文件中行数的最紧凑方法,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/1225589/