[问题] Almost Pi, 内存问题

楼主: Azusa (梓)   2014-07-12 00:57:10
Problem: http://projecteuler.net/problem=461
Code: https://gist.github.com/anonymous/967924f40bb3345d466f
我的算法大概是
1. 找出最大的 k, 使 f_n(k) 不超过 pi (depend on n)
2. 造 dictionary f,使 f = f_n(k)|k=0,..,l
3. 造 two sum dictionary d, 过程中如果碰到两个的和 >= pi 就丢掉
4. lst = list(d) 抓出来 sort
5. 前半 lst 的每一个元素和pi的差做 binary search & 找 minimal value
n = 200 的话没什么问题
但是 n = 10000 实在是太大了
会在 line 31~33 出现 MemoryError
请问要怎么解决这种问题?
作者: ya790206 (残云夺月)   2014-07-12 21:51:00
三种解法,越上面的越好1. 使用Banyan 的 SortedDict 取代内建的 dict2. 自己实作一个类似 dict ,其特性能够将资料暂存到硬盘3. 将 dict 的资料存到 redis(其他或nosql)python 的内建 dict 实作方式是 hashtable,太吃内存。1.5 找其他不是使用 hashtable 来实作dict 的 library
楼主: Azusa (梓)   2014-07-13 11:05:00
谢谢

Links booklink

Contact Us: admin [ a t ] ucptt.com