>php教程 >PHP开发 >PHP로 구현된 방정식 풀이 분석 예

PHP로 구현된 방정식 풀이 분석 예

高洛峰
高洛峰원래의
2016-12-23 15:51:332315검색

이 기사의 예에서는 PHP에서 구현된 방정식 풀이를 설명합니다. 참고를 위해 모든 사람과 공유합니다. 세부 사항은 다음과 같습니다.

1. 요구 사항

1. 평균값을 제공합니다. X2의 최대값과 최소값의 차이, 다음 공식을 만족하세요: 🎜>1)482)0.453)m1, m2, m3은 모두 4자리 양의 소수입니다

2. 구현


필요에 따라 두 가지 기능을 사용하여 처리하는 것을 생각했습니다.

1) 하나는 알려진 평균입니다. 이 평균의 조건을 만족하는 세 숫자 중 createX() 함수를 찾습니다.

2) 다른 하나는 알려진 X입니다. 함수를 찾습니다. 수식(@1)과 경계조건 m0, m1, m2의 소수점 세 자리를 만족하는

구체적인 코드 구현은 다음과 같습니다

<?php
//运行echo "开始运行 \n";
run();
echo "运行结束 \n";
function run()
{/*{{{*/$data = array(40.9, 40.5, 44.3, 47.8, 48.5, 42.1, 46.2);
  $res = array();
  foreach($dataas$key)
  {/*{{{*/echo "处理 {$key}\n";
    $resX = createX($key);
    foreach($resXas$keyX)
    {
      $keyStr = (string)$key;
      $keyXStr = (string)$keyX;
      $res[$keyStr][$keyXStr] = createParams4M($keyX);
    }
  }/*}}}*/error_log(print_r($res,true)."\n", 3, &#39;/tmp/result.log&#39;);
var_dump(99999,$res);exit;
  return$res;
}/*}}}*///1.产生平均数function createX($ave)
{/*{{{*/$sum = 3*($ave * 1000);
  $x1 = $x2 = $x3 = 0;
  $rand4X1X2 = rand(0, 300);
  //$x2 > $x1 > $x3;for($i=0; $i< $ave * 1000 + 550; $i++)
  {
    $x2 = $i;
    $x1 = $x2 - $rand4X1X2;
    $x3 = $sum -($x1 + $x2);
    $positive = $x1 > 0 && $x2 > 0 && $x3 > 0;
    $flag = ($x2- $x3 < 400 && $x2 - $x3 > 200);
    if($positive && $flag)
    {
      //echo "捕捉到\n";$roundX1 = round($x1/1000, 1);
      $roundX2 = round($x2/1000, 1);
      $roundX3 = round($x3/1000, 1);
      $res = array($roundX1, $roundX2, $roundX3);
      $flag = $roundX1 != $roundX2
          && $roundX3 != $roundX2
          && $roundX3 != $roundX1;
      if($flag)
      {
        //echo "捕捉到\n";return$res;
      }
    }
  }
  echo "Fail 未捕捉到\n";
  returnarray($x1, $x2, $x3);
}/*}}}*///2.产生平均数function createParams4M($aveX)
{/*{{{*/$begin = 48000;
  $end = 51000;
  $m0 = $m1 = $m2 = 0;
  $rand4M1M2 = rand(450, 550);
  $m0 = rand($begin, $end);
  $m1 = $m0 + $rand4M1M2;
  $m2 = $m1 - (($m1 - $m0)*$aveX/100);
  //echo "捕捉到\n";returnarray(round($m0/1000, 4), round($m1/1000, 4), round($m2/1000, 4));
}/*}}}*/?>
3. 직면한 문제점과 단점

1. [배열 키 값은 동일할 수 없습니다.] 처음에 접한 것은 평균의 원래 세 값이라는 것입니다. 동일할 수 있지만 키의 배열은 동일할 수 없으므로 일부 처리를 수행했습니다.

동시에 키 값을 문자열로 변환

2. [소수 처리] 또한 소수점 4자리가 포함되기 때문에 루프를 돌면서 출력하는 것이 불편하다. 조건이 충족되었으므로 곱하기 1000을 곱하고 마지막으로 1000으로 나누면 복원됩니다.

이 글이 PHP 프로그래밍에 종사하는 모든 분들께 도움이 되기를 바랍니다.

PHP에서 구현된 방정식 풀이 예제 분석에 대한 더 많은 관련 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.