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

服務器之家:專注于服務器技術及軟件下載分享
分類導航

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

服務器之家 - 編程語言 - PHP教程 - PHP實現的分解質因數操作示例

PHP實現的分解質因數操作示例

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

這篇文章主要介紹了PHP實現的分解質因數操作,結合實例形式分析了php實現分解質因數的相關原理、步驟與操作技巧,需要的朋友可以參考下

本文實例講述了PHP實現的分解質因數操作。分享給大家供大家參考,具體如下:

思路:

如果要計算$num的質數,則至少收集$num以內的質數數組,判斷$num是否在質數數組里:

如果否,則判斷當前質數$zhishu[$i]是否能再次將整除后的數整除,如果能,則質數數組“游標”不移動(還讓當前質數$zhishu[$i]對被整除后的數取模)

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

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

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

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

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

運行結果:

2
3
5
13

希望本文所述對大家PHP程序設計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 三上悠亚国产精品一区 | 含羞草传媒每天免费一次破解 | 我们中文在线观看免费完整版 | 无码天堂亚洲国产AV久久 | 韩国三级日本三级香港三级黄 | 狠狠色狠狠色综合婷婷tag | 校花在公车上被内射好舒 | 日本高清动作片www欧美 | 色欧美亚洲 | 亚洲 另类 欧美 变态屎尿 | 91制片厂制作果冻传媒2021 | 国产精品免费拍拍拍 | 色综合 成人 | 女子监狱第二季未删减在线看 | 男女发生性关系视频 | www.亚洲5555.com| 手机看片国产免费现在观看 | 美女被草哭 | 日产国产精品亚洲系列 | 美女流白浆 | 91精品国产美女福到在线不卡 | 国产特级 | 秋霞理论最新三级理论最 | 男人天堂2023 | 调教麻麻成贱m | 波多野结衣xxxx性精品 | 大逼美女| 亚洲男人天堂a | 亚洲成人一区 | 国产视频久久 | 美女扒开胸罩露出胸大乳 | 国产一区在线看 | 精品欧美一区二区精品久久 | 久久精品人人做人人爽97 | 美女光屁股网站 | 色婷婷六月天 | 亚洲欧洲日产国码天堂 | 精品视频一区二区观看 | 特黄特黄aaaa级毛片免费看 | 无人在线观看免费高清视频播放 | 1024亚洲天堂 |