快速输入背后的逻辑
Logic behind Fast input
谁能解释一下这种快速输入背后的逻辑?我知道它比scanf快。
int scan()
{
int ip=getchar_unlocked(),ret=0;
for(;ip<'0'||ip>'9';ip=getchar_unlocked());
for(;ip>='0'&&ip<='9';ip=getchar_unlocked())
ret=ret*10+ip-'0';
return ret;
}
这里的unlocked
部分是为了避免锁定输入文件(因此,如果多个线程从相同的输入读取,可能会导致问题)。
与其他使用getchar
的人相比,这可能是90%的增益所在,而这反过来可能只比scanf
稍微好一点。显然,scanf
在解析格式字符串方面也有开销,这可能是一些开销。
剩下的代码只是"跳过任何不是数字的内容",然后将一个十进制数读入ret
,当该数字是非数字时停止。
对于读取大量输入,我建议使用fread
(或mmap
或MapViewoOfFile
,如果系统已知支持其中一个调用)在缓冲区中加载大量输入数据,然后使用基于指针的方法"跳过非数字"(假设这是一个"安全"的事情)。这很可能比上面的代码还要快。
相关文章:
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- 2D数组来自文本输入,中间有空格
- 如何使用 < 和 > 命令获取 c++ 中的输入和输出?
- 检查输入是否不是整数或数字
- 正在尝试了解输入验证循环
- 读取文件并输入到矢量中
- C++如何通过用户输入删除列表元素
- 用c++从输入文件中读取另一行
- 读取文件的最后一行并输入到链接列表时出错
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- 如何使用用户输入在C++中正确填充2D数组
- C++MySQL C api用户输入行
- 输入到文件并输出到另一个文件,并将流文件传递给函数
- 用户定义函数中的指针和输入
- 如何在C++中检查2D数组中负值的输入验证
- 如何只允许用户输入正整数
- 在while循环中输入带有std::cin的字符串后,控制台会输出大量胡言乱语
- 输入中的字符串数未知(以字母表示)
- opengl中鼠标输入背后的数学和偏航/俯仰值
- 快速输入背后的逻辑