这里有新鲜出炉的 PHP 教程,程序狗速度看过来!
PHP(外文名: Hypertext Preprocessor,中文名:"超文本预处理器")是一种通用开源脚本语言。语法吸收了 C 语言、Java 和 Perl 的特点,入门门槛较低,易于学习,使用广泛,主要适用于 web 开发领域。PHP 的文件后缀名为 php。
这篇文章主要介绍了 PHP 实现的方程求解, 结合具体实例形式较为详细的分析了针对具体需求使用 php 进行方程求解的实现技巧, 需要的朋友可以参考下
本文实例讲述了 PHP 实现的方程求解。分享给大家供大家参考,具体如下:
一、需求
1. 给出一个平均值 X,反过来求出来,得到这个平均值 X 的三个数 X1 ,X2, X3,最大值与最小值的差值要小于 0.4(X1-X3 都是保留 1 位小数的数)
2. 这三个数 X1, X2, X3 代表了三组数。满足下面的公式: X1 = [(m1 - m2)/(m1 - m0) ] * 100 (@1);
m0, m1, m2 三个数的边界条件如下:
1)48
2)0.45
3)m1, m2, m3 都是 4 位的正小数
二、实现
根据需求,我想到了使用两个函数来进行处理。
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, '/tmp/result.log');
- 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));
- }/*}}}*/?>
三、遇到的问题和不足之处
1. 【数组 key 值不能相同】开始遇到的是 得到的平均数的原始三个值有可能有相同的,但是数组中的 key 是不能相同的,于是做了处理。
同时,key 值做了 string 的转化
2. 【小数处理】还有就是 因为涉及的是 4 位的小数,循环遍历,满足条件输出不方便,就 乘以 1000 扩大倍数,最后再除以 1000 还原。
希望本文所述对大家 PHP 程序设计有所帮助。
来源: http://www.phperz.com/article/17/0810/341321.html