ruby 簡單例子
2019-10-26 19:19:04
供稿:網友
讓我們寫一個計算階乘的函數.對于階乘的數學定義如下:
n! = 1 (當 n==0 時)
= n * (n-1)! (其它情況)
在Ruby里,可以這樣來寫:
代碼如下:
def fact(n)
if n == 0
1
else
n * fact(n-1)
end
end
你可能會發現 end 的反復出現,正因為如此,Ruby被叫做"類Algol"語言.(實際上,Ruby的語法更像Eiffel).同時,你也可能會發現這段函數缺少return語句.在這里是可以用return的,但卻不是必須的,因為一個Ruby的函數會自動返回它所最后賦值的元素.
讓我們來試試我們的階乘函數.加入一行代碼會使它成為一個可工作的程序:
代碼如下:
# Program to find the factorial of a number
# Save this as fact.rb
def fact(n)
if n == 0
1
else
n * fact(n-1)
end
end
print fact(ARGV[0].to_i), "/n"
這里,ARGV是一個包含命令行參數的數組,to_i將字符串轉化為整數.
% ruby fact.rb 1
1
% ruby fact.rb 5
120
當參數為40時它可以工作嗎?它將使你的計算器產生溢出(overflow)...
% ruby fact.rb 40
815915283247897734345611269596115894272000000000
它確實算出來了.實際上,Ruby能處理任何你機器的內存所允許的整數.實際上400!也可以:
% ruby fact.rb 400
64034522846623895262347970319503005850702583026002959458684
44594280239716918683143627847864746326467629435057503585681
08482981628835174352289619886468029979373416541508381624264
61942352307046244325015114448670890662773914918117331955996
44070954967134529047702032243491121079759328079510154537266
72516278778900093497637657103263503315339653498683868313393
52024373788157786791506311858702618270169819740062983025308
59129834616227230455833952075961150530223608681043329725519
48526744322324386699484224042325998055516106359423769613992
31917134063858996537970147827206606320217379472010321356624
61380907794230459736069956759583609615871512991382228657857