2017-02-24 88 views
0

我一直在努力創建一個素數的數組。到目前爲止,我已經在它列出所有素數從2到1000的地方工作。我現在要做的是使用增量計數< 100或類似的東西生成前100個素數。這是我目前的代碼。使用循環填充第一個100個素數的數組

<?php 

function prima($n) 
{ 
$primeNumbers = []; // Initiate result array 
for ($i = 1; $i <= $n; $i++) 
    { 
    $counter = 0; 
    for ($j = 1; $j <= $i; $j++) 
     { 
     if ($i % $j == 0) 
      { 
      $counter++; 
      } 
     } 

    if ($counter == 2) 
     { 
     $primeNumbers[] = $i; // store value to array 
     } 
    } 

return json_encode($primeNumbers); // return converted json object 
} 

header('Content-Type: application/json'); // tell browser what to expect 
echo prima(1000); // echo the json string returned from function 

?> 
+1

當你達到極限時,只要跳出循環:'if($ counter == 100)break;' – Barmar

回答

1

在for循環結束時,添加'if(count($ primeNumbers)== 100)break;'

+0

這就是我想要做的。謝謝 – user2168066