一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - PHP教程 - PHP實(shí)現(xiàn)的分解質(zhì)因數(shù)操作示例

PHP實(shí)現(xiàn)的分解質(zhì)因數(shù)操作示例

2019-09-17 13:36misaka去年夏天 PHP教程

這篇文章主要介紹了PHP實(shí)現(xiàn)的分解質(zhì)因數(shù)操作,結(jié)合實(shí)例形式分析了php實(shí)現(xiàn)分解質(zhì)因數(shù)的相關(guān)原理、步驟與操作技巧,需要的朋友可以參考下

本文實(shí)例講述了PHP實(shí)現(xiàn)的分解質(zhì)因數(shù)操作。分享給大家供大家參考,具體如下:

思路:

如果要計(jì)算$num的質(zhì)數(shù),則至少收集$num以內(nèi)的質(zhì)數(shù)數(shù)組,判斷$num是否在質(zhì)數(shù)數(shù)組里:

如果否,則判斷當(dāng)前質(zhì)數(shù)$zhishu[$i]是否能再次將整除后的數(shù)整除,如果能,則質(zhì)數(shù)數(shù)組“游標(biāo)”不移動(dòng)(還讓當(dāng)前質(zhì)數(shù)$zhishu[$i]對(duì)被整除后的數(shù)取模)

如果不能(再次將整除后的數(shù)整除),則用下一個(gè)質(zhì)數(shù)(讓$i++)去測試是否整除。如果否($num在質(zhì)數(shù)數(shù)組里),則表示$num本身就是個(gè)質(zhì)數(shù),直接echo之。(思路看得糊涂的話,直接看代碼吧)

首先:用一個(gè)函數(shù)收集一定范圍內(nèi)的質(zhì)數(shù)放到數(shù)組里返回。(把1從質(zhì)數(shù)里剔除,從2開始算質(zhì)數(shù)),代碼和注釋如下:

//得到1000以內(nèi)的質(zhì)數(shù)
function get_zhishu($num=1000){
  $num = floor($num);
  $zhishu = array();
  //先得到1000以內(nèi)的質(zhì)數(shù)
  for($i=1; $i<=$num; $i++){
    $flag = true; //當(dāng)flag為false時(shí)表示該數(shù)不是素?cái)?shù)
    for($j=2; $j<$num; $j++){ //$j從2開始,因?yàn)槌龜?shù)為1時(shí),肯定能整除
      if($i>$j){ //$j如果比$i還大,取模肯定不為0,沒有比較的意義
        $mod = $i%$j;
        if($mod == 0 ){ //當(dāng)除數(shù)$j為$i以內(nèi)時(shí),如果取模為0,表示該數(shù)不是素?cái)?shù)
          $flag = false;
        }
      }
    }
    if($flag){
      array_push($zhishu, $i);//如果$flag為真,則$i是質(zhì)數(shù)
    }
  }
  array_shift($zhishu); //把1從質(zhì)數(shù)數(shù)組中剔除
  return $zhishu;
}
$zhishu = get_zhishu(1000); //得到1到1000之內(nèi)的質(zhì)數(shù)

然后:從質(zhì)數(shù)數(shù)組中,挨個(gè)取出(從最小的質(zhì)數(shù)開始)符合條件(能被整除)的質(zhì)數(shù)。代碼和注釋如下:

/**
 * @param int $num 要分解的質(zhì)數(shù)
 * @param array $zhishu 1000以內(nèi)的質(zhì)數(shù)數(shù)組
 * @param int $i 相當(dāng)于質(zhì)數(shù)數(shù)組的"游標(biāo)"
 * @author misaka去年夏天
 */
function fenjie_num($num, $zhishu, $i=0){
  if(!is_int($num) || $num<0){
    exit('請(qǐng)輸入正整數(shù)!');
  }
  if(in_array($num, $zhishu)){ //如果該數(shù)為質(zhì)數(shù),則echo之
    echo $num,'<br />';
  }else{
    $ceil = ceil($num/$zhishu[$i]);
    if($ceil == ($num/$zhishu[$i])){
      echo $zhishu[$i],'<br />';
      if($ceil%$zhishu[$i]!=0){
        //如果當(dāng)前質(zhì)數(shù)還能被$ceil整除,則繼續(xù)用該質(zhì)數(shù)(不用$i++),比如90分解為2、3、3、5,否則讓$i++再遞歸
        $i++;
      }
      fenjie_num((int)$ceil, $zhishu, $i);
    }else{
      fenjie_num($num, $zhishu, $i+1); //對(duì)于99這樣的,不是質(zhì)數(shù),但也沒第一次被整除的,用下一個(gè)質(zhì)數(shù)($i++)測試它
    }
  }
}
fenjie_num(390, $zhishu);

運(yùn)行結(jié)果:

2
3
5
13

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 91久久偷偷做嫩草影院免费看 | 国产精品1页 | 国产成人a∨麻豆精品 | 国产偷窥女洗浴在线观看亚洲 | 亚洲精品免费视频 | 青青在线观看视频 | 欧美sq| 91大神亚洲影视在线 | 无限在线看免费视频大全 | 国产精品久久久久久网站 | 日本一区三区 | eeuss免费快捷 | 九九精品免费视频 | 精精国产xxxx视频在线播放器 | 久久成人亚洲 | 四虎在线观看 | 国产精品色爱综合网 | 日韩在线观看一区二区不卡视频 | 日本三级在丈面前被耍了 | 女人pp被扒开流水了 | 魔法满屋免费观看完整版中文 | 亚洲色大成网站www久久九九 | www国产精品| 97热在线 | 我要看黄色毛片 | 青草青草伊人精品视频 | 欧美国产日韩综合 | 动漫美女隐私尿口图片 | 国产伦精品一区二区三区女 | 欧美xbxbxbxb大片 | 亚洲成人第一 | 午夜亚洲WWW湿好爽 午夜想想爱午夜剧场 | 午夜精品久久久久 | 亚洲一区二区三区在线播放 | youzljzljzljzlj96 | 91精品国产综合久久福利 | 男人晚上适合偷偷看的污污 | 91在线 在线播放 | 久久草福利自拍视频在线观看 | 免费高清在线视频色yeye | 免费国产福利 |