濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > PHP實(shí)現(xiàn)的分解質(zhì)因數(shù)操作示例

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

熱門(mén)標(biāo)簽:太原400電話申請(qǐng)流程 萍鄉(xiāng)商鋪地圖標(biāo)注 神龍斗士電話機(jī)器人 合肥企業(yè)外呼系統(tǒng)線路 代理打電話機(jī)器人 宿州正規(guī)外呼系統(tǒng)軟件 電信外呼系統(tǒng)多少錢(qián)一個(gè)月 企業(yè)400電話辦理多少費(fèi)用 桂陽(yáng)公司如何做地圖標(biāo)注

本文實(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++)去測(cè)試是否整除。如果否($num在質(zhì)數(shù)數(shù)組里),則表示$num本身就是個(gè)質(zhì)數(shù),直接echo之。(思路看得糊涂的話,直接看代碼吧)

首先:用一個(gè)函數(shù)收集一定范圍內(nèi)的質(zhì)數(shù)放到數(shù)組里返回。(把1從質(zhì)數(shù)里剔除,從2開(kāi)始算質(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開(kāi)始,因?yàn)槌龜?shù)為1時(shí),肯定能整除
      if($i>$j){ //$j如果比$i還大,取模肯定不為0,沒(méi)有比較的意義
        $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ù)開(kāi)始)符合條件(能被整除)的質(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) || $num0){
    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ù),但也沒(méi)第一次被整除的,用下一個(gè)質(zhì)數(shù)($i++)測(cè)試它
    }
  }
}
fenjie_num(390, $zhishu);

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

2
3
5
13

PS:這里再為大家推薦幾款計(jì)算工具供大家進(jìn)一步參考借鑒:

在線分解質(zhì)因數(shù)計(jì)算器工具:
http://tools.jb51.net/jisuanqi/factor_calc

在線一元函數(shù)(方程)求解計(jì)算工具:
http://tools.jb51.net/jisuanqi/equ_jisuanqi

科學(xué)計(jì)算器在線使用_高級(jí)計(jì)算器在線計(jì)算:
http://tools.jb51.net/jisuanqi/jsqkexue

在線計(jì)算器_標(biāo)準(zhǔn)計(jì)算器:
http://tools.jb51.net/jisuanqi/jsq

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》及《php正則表達(dá)式用法總結(jié)》

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

您可能感興趣的文章:
  • PHP計(jì)算個(gè)人所得稅示例【不使用速算扣除數(shù)】
  • PHP實(shí)現(xiàn)的簡(jiǎn)單四則運(yùn)算計(jì)算器功能示例
  • PHP基于堆棧實(shí)現(xiàn)的高級(jí)計(jì)算器功能示例
  • PHP數(shù)據(jù)分析引擎計(jì)算余弦相似度算法示例
  • PHP實(shí)現(xiàn)的簡(jiǎn)單在線計(jì)算器功能示例
  • php編程實(shí)現(xiàn)簡(jiǎn)單的網(wǎng)頁(yè)版計(jì)算器功能示例
  • PHP房貸計(jì)算器實(shí)例代碼,等額本息,等額本金
  • PHP中浮點(diǎn)數(shù)計(jì)算比較及取整不準(zhǔn)確的解決方法
  • PHP精確計(jì)算功能示例
  • PHP中使用微秒計(jì)算腳本執(zhí)行時(shí)間例子

標(biāo)簽:鄂州 衡陽(yáng) 廊坊 綏化 白銀 崇左 辛集 太原

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP實(shí)現(xiàn)的分解質(zhì)因數(shù)操作示例》,本文關(guān)鍵詞  PHP,實(shí)現(xiàn),的,分解,質(zhì)因數(shù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP實(shí)現(xiàn)的分解質(zhì)因數(shù)操作示例》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于PHP實(shí)現(xiàn)的分解質(zhì)因數(shù)操作示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    灌云县| 孟州市| 洛宁县| 县级市| 伊春市| 长春市| 惠州市| 凤山县| 高唐县| 樟树市| 保定市| 彰化市| 射洪县| 余干县| 鸡泽县| 孟津县| 贵定县| 托克托县| 武功县| 武邑县| 通江县| 神农架林区| 正定县| 如东县| 张掖市| 福海县| 建德市| 新郑市| 黑龙江省| 景泰县| 承德市| 隆子县| 南城县| 毕节市| 衡阳县| 大丰市| 丹东市| 中江县| 江达县| 新平| 漳州市|