谷姐:我们都是谷歌迷
We are all Google fans

抛砖引玉个无聊的东西,搜索数字在圆周率前10亿位的位置-etc小号

Rate this post

wget https://zxd.coding.net/p/pi/d/pi/git/raw/master/pi.tar.gz

tar zxvf pi.tar.gz

得到pi.txt

wget https://zxd.coding.net/p/pi/d/pi/git/raw/master/pi.php

把pi.txt和上面这个php文件放一起,参数就一个s,s是需要查询的数字

不怎么懂代码,所以写的很烂,但是能用

目前主要有这样的问题,这个txt大概950m,并且都在一行里面,php检索起来很慢

用我那个代码的话,遍历大概要5秒钟,但是不怎么耗内存

有没有大佬能优化下,通过数据库或者什么算法,让搜索更快点

还有就是有没有办法和公众号配合,实现在公众号里面查询

热议
2楼 表妹 昨天20:54

你的头像让我怀念op

3楼 davidsky2012 昨天21:03

可以试试用4个数字来建索引:
0000 => 所有0000开头的数字位置
0001 => 所有0001开头的数字位置
...
9999 => 所有9999开头的数字位置

也可以试试用3个或5个数字建索引,比较下哪种方式更节省CPU和内存。

4楼 sdqu 昨天21:06

1. 读入内存长驻
2. 自己用C写搜索,算法课本里有的
3. 进程间通讯

5楼 davidsky2012 昨天21:13

1. 读入内存长驻
2. 自己用C写搜索,算法课本里有的
3. 进程间通讯

C语言字符串搜索函数自带kmp等高效算法吧,不用自己实现。

感觉楼主并不想把900多M一起读入内存。

6楼 sdqu 昨天21:18

C语言字符串搜索函数自带kms等高效算法吧,不用自己实现。

感觉楼主并不想把900多M一起读入内存。 ...

道理上确实是的,不过实际使用中,c的字符串搜索,比如strstr并不高效,映象中有替代的string库更高效一些。自己按照算法写,最好是内嵌汇编来得最快。这个我以前做项目时遇到过。
楼主是用纯php写,这个肯定不能读进内存了,每次读文件,效率肯定不行的。用数据库等辅助另议。
因为楼主标题也说了是无聊讨论算法嘛,所以我按照最高效的方法来说了,没局限在他的那个php代码了。

7楼 破刀 2小时前

3.1415926.xyz 路过

/**
* MJJ命运啊,说是注定,不如说是你忘了是在何时做了选择。——《塔希里亚故事集》
*
* 森林鸟 forestbird Link https://bird.work
*/

8楼 zxxx 2小时前

破刀 发表于 2022-2-21 08:53
3.1415926.xyz 路过

300CNY收了一个3.1415926.xyz

+1

9楼 etc小号 16分钟前

300CNY收了一个3.1415926.xyz

+1

好域名

申明:本文内容由网友收集分享,仅供学习参考使用。如文中内容侵犯到您的利益,请在文章下方留言,本站会第一时间进行处理。

未经谷姐允许不得转载:谷姐靓号网 » 抛砖引玉个无聊的东西,搜索数字在圆周率前10亿位的位置-etc小号
分享到: 生成海报

热门文章

评论 抢沙发

评论前必须登录!

立即登录   注册

买Google Voice认准【谷姐靓号网】

Google Voice靓号列表Google Voice自助购买
切换注册

登录

忘记密码 ?

切换登录

注册

我们将发送一封验证邮件至你的邮箱, 请正确填写以完成账号注册和激活