在之前的文章《PHP循環學習十:判定水仙花數,打印全部水仙花數》中,我們給大家介紹一下判斷水仙花數並利用循環輸出所有水仙花數的方法,下面繼續php循環的學習,介紹一下怎麼判斷一個數字是不是素數,並輸出1~100的素數,感興趣的朋友可以學習了解一下~
首先我們來了解一下什麼是質數?
素數(質數)是指除了1和它本身之外再不能被其他數整除的自然數;如果能被其他數整除則稱為合數(規定1既不是質數也不是合數)。
例如:數字2、3、17、19都是質數,它們只能被1和本身整除。
那麼如果給一個數 num(例如17),我們怎麼判斷這個數 num 是不是質數呢? 下面要跟大家介紹幾種方法:
方法1:最簡單的方法是根據質數的定義來求
思路:
素數只能被1和本身整除,也就是只能被整除2次。
因此我們利用循環,使用大於1小於等於N的各個自然數都去除一下N,統計被整除的次數,如果次數大於2則不是質數;如果等於2則是質數。
下面來看看實作程式碼:
<?php header("content-type:text/html;charset=utf-8"); $num=17; $count = 1; for($i = 2; $i <= $num; $i++) { if(($num % $i)== 0) $count ++; } if($count == 2) { echo $num . '就是素数<br/>'; }else{ echo $num . '不是素数<br/>'; } ?>
輸出結果:
##方法2:
思路:用一個數分別去除2到sqrt(這個數),如果能被整除,則表示此數不是質數,反之是質數。
<?php header("content-type:text/html;charset=utf-8"); $num=19; $flag = 1; for($i = 2; $i*$i <= $num; $i++) //能被2 - sqrt(i)整除的数 { if($num % $i == 0) { $flag = 0; break; } } if($flag == 1) { echo $num . '就是素数<br/>'; }else{ echo $num . '不是素数<br/>'; } ?>輸出結果:
怎麼給定一個範圍(例如1~100),輸出全部質數呢?
是不是要使用兩個循環,在上面for迴圈的基礎上,在外面套一層for迴圈來控制範圍即可。讓我們來看看實作程式碼(直接使用方法2的程式碼):<?php header("content-type:text/html;charset=utf-8"); $count = 0; for($k = 2; $k <= 100; $k++){ //从2开始,遍历到100 $flag = 1; for($i = 2; $i*$i <= $k; $i++) {//能被2 - sqrt(i)整除的数 if($k % $i == 0) { $flag = 0; break; } } if($flag == 1) { echo $k . '是素数<br/>'; $count ++; } } echo '<br/>1~100间共有 '.$count." 个素数"; ?>輸出結果:
$count,每輸出一個質數後,自增1,這樣就可以統計出1~100內有多少質數了。
推薦:《PHP面試題大匯總(收藏)》
以上是PHP循環學習十一:怎麼判斷素數並印出1~100的質數、統計其數目的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

禪工作室 13.0.1
強大的PHP整合開發環境

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

記事本++7.3.1
好用且免費的程式碼編輯器