将文件转换为列表c++的最快方法
fastest way to convert a file to list c++
我有一个装满整数的文件,经过排序,我需要将文件的内容放到列表中。文件看起来像这样:
1
4
45
150
245
365
我知道可以逐行读取和pushback,但文件数超过了500000行,所以他们是一种快速的方法吗?
目标是查看文件中是否有整数,因此我需要转换为list,然后进行binarysearch,如果您有更好的想法,我将不胜感激。
要读取列表,可以使用std::istreambuf_iterator
:
std::ifstream t( "file.txt");
std::list<int> l( ( std::istreambuf_iterator<int>( t)),
std::istreambuf_iterator<int>());
如果您想多次搜索,我建议将文件内容放入哈希表中。这将为您提供最佳的O(1)查找。
我会这样做:
#include <iostream>
#include <iterator>
#include <unordered_set>
int main() {
std::ifstream t { "file.txt", ios::ate };
std::unordered_set s;
s.reserve(t.tellg());
t.seekg(0);
s.insert(std::istream_iterator<int>(t), std::istream_iterator<int>());
// now you can use s.find(key) to see if something is in the set
}
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- 通过方法访问结构
- 最小硬币更换问题(自上而下方法)
- C++为构建时间获取QDateTime的可靠方法
- 在C#中处理C++指针而不使用unsafe的最佳方法
- 处理多个异常集合的C++方法
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 有什么方法可以遍历结构吗
- 当类在C++中定义时,有什么方法可以"register"类吗?
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- 使用std::函数映射对象方法
- 有符号的int和int-有没有一种方法可以在C++中区分它们
- C++从另一个类访问公共静态向量的正确方法是什么
- C++优先级队列,按对象的唯一指针的特定方法升序排列
- 没有为自己的结构调用列表推回方法
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 在类定义之后定义一个私有方法
- 枚举环境变量的惯用C++14/C++17方法
- 初始化具有非默认构造函数的std::数组项的更好方法