国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Ruby、PHP、Shell實現求50以內的素數

2019-10-26 19:24:30
字體:
來源:轉載
供稿:網友

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 翼城县| 迁安市| 金昌市| 酒泉市| 青岛市| 南漳县| 长顺县| 塔河县| 婺源县| 潼南县| 突泉县| 吕梁市| 白河县| 渑池县| 当涂县| 织金县| 巴东县| 湘潭县| 台东市| 宜州市| 宁德市| 陆良县| 巴彦淖尔市| 黄冈市| 中宁县| 合阳县| 泰宁县| 临猗县| 香格里拉县| 新巴尔虎右旗| 宁德市| 延吉市| 沅陵县| 洛阳市| 新密市| 闻喜县| 河池市| 龙川县| 东安县| 玉山县| 新巴尔虎右旗|