Ruby、PHP、Shell實(shí)現(xiàn)求50以內(nèi)的素?cái)?shù)
ruby求50之內(nèi)的素?cái)?shù)的方法,感覺對(duì)比PHP和SHELL方法是最簡(jiǎn)單的,但SHELL中可以利用factor命令,而PHP中沒有求素?cái)?shù)的對(duì)應(yīng)函數(shù)的,需要自己設(shè)計(jì)算法,三種方式大家對(duì)比學(xué)習(xí)下,應(yīng)該還有更優(yōu)更簡(jiǎn)單的方法的。
#encoding:utf-8
#求50以內(nèi)的素?cái)?shù)(注意數(shù)字中..與...的區(qū)別)
for i in 2..50 #1默認(rèn)不為素?cái)?shù),所以從1-50范圍內(nèi)被排除
f=true #起始假定每個(gè)數(shù)都是素?cái)?shù)
for p in 2...i #比自身小的正整數(shù)(1和自身除外)
if i%p==0 #如果能整除
f=nil#那么這個(gè)數(shù)不是素?cái)?shù)
break #并且跳出這層循環(huán)
end # if 結(jié)束
end #內(nèi)層循環(huán)結(jié)束
print i," " if f #如果這個(gè)數(shù)保持起始假定,則打印
end #外層循環(huán)結(jié)束
PHP代碼如下:
<?php
echo "以下程序會(huì)輸出50以內(nèi)的素?cái)?shù):";
for($m=1;$m<=50;$m++){ //第一層循環(huán),循環(huán)1-50直接的所有數(shù)
$k=0; //計(jì)數(shù)器初始化
for($i=1;$i<=$m;$i++){ //第二層循環(huán),循環(huán)1-$m直接的所有數(shù),$m<=$n
if($m%$i==0){ //取模運(yùn)算,如果余數(shù)為0,K自增1
$k++;
}
}
if($k==2){ //如果k的值等于1或者2,那么是素?cái)?shù),將其輸出
echo $m." ";
}
}
?>
SHELL的方式略為簡(jiǎn)單些,代碼如下:
#!/bin/bash
#factor是shell命令,可以求出后面所接數(shù)字中的所有素?cái)?shù)。
for i in {2..50}
do
factor $i | awk -F '[: ]' '{if(NF == 3) print $1}'
done
- PHP+shell實(shí)現(xiàn)多線程的方法
- php-fpm開機(jī)自動(dòng)啟動(dòng)Shell腳本
- Shell、Perl、Python、PHP訪問 MySQL 數(shù)據(jù)庫代碼實(shí)例
- Shell腳本中實(shí)現(xiàn)更新PHP5
- Shell腳本實(shí)現(xiàn)啟動(dòng)PHP內(nèi)置FastCGI Server
- PHP和Shell實(shí)現(xiàn)檢查SAMBA與NFS Server是否存在
- shell腳本聯(lián)合PHP腳本采集網(wǎng)站的pv和alexa排名
- php管理nginx虛擬主機(jī)shell腳本實(shí)例
- 監(jiān)控服務(wù)器swap并重啟php的Shell腳本
- PHP+shell腳本操作Memcached和Apache Status的實(shí)例分享
相關(guān)文章
設(shè)計(jì)模式中的模板方法模式在Ruby中的應(yīng)用實(shí)例兩則
這篇文章主要介紹了設(shè)計(jì)模式中的模板方法模式在Ruby中的應(yīng)用實(shí)例兩則,經(jīng)典的項(xiàng)目經(jīng)理例子在這里又被套上用了^^需要的朋友可以參考下2016-03-03
使用Ruby on Rails和PostgreSQL自動(dòng)生成UUID的教程
這篇文章主要介紹了使用Ruby on Rails和PostgreSQL自動(dòng)生成UUID的教程,主要利用到了PostgreSQL的插件uuid-ossp,需要的朋友可以參考下2015-04-04
Ruby中的Proc類及Proc的類方法Proc.new的使用解析
用Proc類可以用Proc.new來創(chuàng)建一個(gè)Proc類,進(jìn)而來操作塊,這里我們就來進(jìn)行Ruby中的Proc類及Proc的類方法Proc.new的使用解析.2016-05-05
ruby+nokogori抓取糗事百科前10頁并存儲(chǔ)進(jìn)數(shù)據(jù)庫示例
這篇文章主要介紹了ruby+nokogori抓取糗事百科前10頁并存儲(chǔ)進(jìn)數(shù)據(jù)庫示例,需要的朋友可以參考下2014-05-05

