歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux編程 >> Linux編程 >> Ruby中求50之內的素數方法

Ruby中求50之內的素數方法

日期:2017/3/1 9:35:03   编辑:Linux編程

Ruby求50之內的素數的方法,感覺對比PHP和SHELL方法是最簡單的,但SHELL中可以利用factor命令,而PHP中沒有求素數的對應函數的,需要自己設計算法,三種方式大家對比學習下,應該還有更優更簡單的方法的。

#encoding:utf-8
#求50以內的素數(注意數字中..與...的區別)

for i in 2..50 #1默認不為素數,所以從1-50范圍內被排除
f=true #起始假定每個數都是素數
for p in 2...i #比自身小的正整數(1和自身除外)
if i%p==0 #如果能整除
f=nil#那麼這個數不是素數
break #並且跳出這層循環
end # if 結束
end #內層循環結束
print i," " if f #如果這個數保持起始假定,則打印
end #外層循環結束

PHP代碼如下:

<?php
echo "以下程序會輸出50以內的素數:";
for($m=1;$m<=50;$m++){ //第一層循環,循環1-50直接的所有數
$k=0; //計數器初始化
for($i=1;$i<=$m;$i++){ //第二層循環,循環1-$m直接的所有數,$m<=$n
if($m%$i==0){ //取模運算,如果余數為0,K自增1
$k++;
}
}
if($k==2){ //如果k的值等於1或者2,那麼是素數,將其輸出
echo $m." ";
}
}
?>

SHELL的方式略為簡單些,代碼如下:

#!/bin/bash
#factor是shell命令,可以求出後面所接數字中的所有素數。
for i in {2..50}
do
factor $i | awk -F '[: ]' '{if(NF == 3) print $1}'
done

Ruby中的遍歷指定目錄的文件方法 http://www.linuxidc.com/Linux/2015-01/111525.htm

Ubuntu下搭建Ruby On Rails http://www.linuxidc.com/Linux/2012-06/61981.htm

實測 Ubuntu 13.10 上搭建 Ruby on Rails http://www.linuxidc.com/Linux/2014-02/96399.htm

Ruby on Rails 4 Tutorial 中文版 高清完整PDF http://www.linuxidc.com/Linux/2014-04/100253.htm

Ruby 的詳細介紹:請點這裡
Ruby 的下載地址:請點這裡

Copyright © Linux教程網 All Rights Reserved