久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長(zhǎng)資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      PHP循環(huán)學(xué)習(xí)十一:怎么判斷素?cái)?shù)并打印1~100的素?cái)?shù)、統(tǒng)計(jì)其數(shù)目

      在之前的文章《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é)果:

      PHP循環(huán)學(xué)習(xí)十一:怎么判斷素?cái)?shù)并打印1~100的素?cái)?shù)、統(tǒng)計(jì)其數(shù)目

      方法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é)果:

      PHP循環(huán)學(xué)習(xí)十一:怎么判斷素?cái)?shù)并打印1~100的素?cái)?shù)、統(tǒng)計(jì)其數(shù)目

      好了知道怎么給定一個(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é)果:

      PHP循環(huán)學(xué)習(xí)十一:怎么判斷素?cái)?shù)并打印1~100的素?cái)?shù)、統(tǒng)計(jì)其數(shù)目

      可以看出,我們?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面試題大匯總(收藏)》

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)