计算文件行数的最紧凑方法是什么?
我需要这些信息来创建/初始化矩阵数据结构。

稍后我必须再次浏览文件并将信息存储在矩阵中。

更新: 基于 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/

10-16 03:58
查看更多