我正在瀏覽projecteuler.net上的問題,以瞭解如何使用Erlang進行編程,而且我最難創建一個能夠創建低於200萬的所有素數的主要生成器,一分鐘。使用順序式,我已經寫了三種類型的生成器,包括Eratosthenes的Sieve,並且它們都不夠好。併發素數生成器
我想到一個併發Sieve會很好,但我得到bad_arity消息,我不知道爲什麼。關於爲什麼我遇到問題或者如何正確編寫代碼的任何建議?
這裏是我的代碼中,註釋掉的部分在哪裏我試圖讓事情併發:
-module(primeserver). -compile(export_all). start() -> register(primes, spawn(fun() -> loop() end)). is_prime(N) -> rpc({is_prime,N}). rpc(Request) -> primes ! {self(), Request}, receive {primes, Response} -> Response end. loop() -> receive {From, {is_prime, N}} -> if N From ! {primes, false}; N =:= 2 -> From ! {primes, true}; N rem 2 =:= 0 -> From ! {primes, false}; true -> Values = is_not_prime(N), Val = not(lists:member(true, Values)), From ! {primes, Val} end, loop() end. for(N,N,_,F) -> [F(N)]; for(I,N,S,F) when I + S [F(I)|for(I+S, N, S, F)]; for(I,N,S,F) when I + S =:= N -> [F(I)|for(I+S, N, S, F)]; for(I,N,S,F) when I + S > N -> [F(I)]. get_list(I, Limit) -> if I [I*A || A [] end. is_not_prime(N) -> for(3, N, 2, fun(I) -> List = get_list(I,trunc(N/I)), lists:member(N,lists:flatten(List)) end ). %%L = for(1,N, fun() -> spawn(fun(I) -> wait(I,N) end) end), %%SeedList = [A || A %% lists:foreach(fun(X) -> %% Pid ! {in_list, X} %% end, SeedList) %% end, L). %%wait(I,N) -> %% List = [I*A || A lists:member(X,List) %% end.
你是如何壓制Markdown不恰當的語法着色的? – 2008-09-30 15:58:26