在之前的文章《PHP循環(huán)學(xué)習(xí)十:判定水仙花數(shù),打印全部水仙花數(shù)》中,我們給大家介紹一下判斷水仙花數(shù)并利用循環(huán)輸出所有水仙花數(shù)的方法,下面繼續(xù)php循環(huán)的學(xué)習(xí),介紹一下怎么判斷一個(gè)數(shù)是不是素?cái)?shù),并輸出1~100的素?cái)?shù),感興趣的朋友可以學(xué)習(xí)了解一下~
首先我們來了解一下什么是素?cái)?shù)?
素?cái)?shù)(質(zhì)數(shù))是指除了1和它本身之外再不能被其他數(shù)整除的自然數(shù);如果能被其他數(shù)整除則稱為合數(shù)(規(guī)定1既不是質(zhì)數(shù)也不是合數(shù))。
例如:數(shù)字2、3、17、19都是素?cái)?shù),它們只能被1和本身整除。
那么如果給出一個(gè)數(shù) num(例如17),我們?cè)趺磁袛噙@個(gè)數(shù) num 是不是素?cái)?shù)呢?下面給大家介紹幾種方法:
方法1:最簡(jiǎn)單的方法是根據(jù)素?cái)?shù)的定義來求
思路:
-
素?cái)?shù)只能被1和本身整除,即只能被整除2次。
-
因此我們利用循環(huán),使用大于1小于等于N的各個(gè)自然數(shù)都去除一下N,統(tǒng)計(jì)被整除的次數(shù),如果次數(shù)大于2則不是素?cái)?shù);如果等于2則則是素?cái)?shù)。
下面來看看實(shí)現(xiàn)代碼:
<?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 . '就是素?cái)?shù)<br/>'; }else{ echo $num . '不是素?cái)?shù)<br/>'; } ?>
輸出結(jié)果:
方法2:
思路:用一個(gè)數(shù)分別去除2到sqrt(這個(gè)數(shù))
,如果能被整除,則表明此數(shù)不是素?cái)?shù),反之是素?cái)?shù)。
下面來看看實(shí)現(xiàn)代碼:
<?php header("content-type:text/html;charset=utf-8"); $num=19; $flag = 1; for($i = 2; $i*$i <= $num; $i++) //能被2 - sqrt(i)整除的數(shù) { if($num % $i == 0) { $flag = 0; break; } } if($flag == 1) { echo $num . '就是素?cái)?shù)<br/>'; }else{ echo $num . '不是素?cái)?shù)<br/>'; } ?>
輸出結(jié)果:
好了知道怎么給定一個(gè)數(shù)來判斷是不是素?cái)?shù)了,下面加大難度:怎么給定一個(gè)范圍(例如1~100),輸出全部素?cái)?shù)呢?
是不是要使用兩個(gè)循環(huán),在上面for循環(huán)的基礎(chǔ)上,在外面套一層for循環(huán)來控制范圍即可。我們來看看實(shí)現(xiàn)代碼(直接使用方法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)整除的數(shù) if($k % $i == 0) { $flag = 0; break; } } if($flag == 1) { echo $k . '是素?cái)?shù)<br/>'; $count ++; } } echo '<br/>1~100間共有 '.$count." 個(gè)素?cái)?shù)"; ?>
輸出結(jié)果:
可以看出,我們?cè)趦?nèi)層for循環(huán)的循環(huán)體中,使用一個(gè)計(jì)數(shù)器$count
,每輸出一個(gè)素?cái)?shù)后,自增1,這樣就可以統(tǒng)計(jì)出1~100內(nèi)有多少素?cái)?shù)了。
好了就說到這里了,有其他想知道的,可以點(diǎn)擊這個(gè)哦?!?→php視頻教程
推薦:《PHP面試題大匯總(收藏)》