PHP实现的方程求解示例分析


Posted in PHP onNovember 11, 2016

本文实例讲述了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<m0<51
2)0.45<m1 - m1<0.55
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程序设计有所帮助。

PHP 相关文章推荐
php连接mysql数据库代码
Mar 10 PHP
php安全之直接用$获取值而不$_GET 字符转义
Jun 03 PHP
php网站地图生成类示例
Jan 13 PHP
php多功能图片处理类分享(php图片缩放类)
Mar 14 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(五)
Jun 23 PHP
linux中cd命令使用详解
Jan 08 PHP
php+xml结合Ajax实现点赞功能完整实例
Jan 30 PHP
PHP页面跳转操作实例分析(header方法)
Sep 28 PHP
详谈php ip2long 出现负数的原因及解决方法
Apr 05 PHP
PHP使用微信开发模式实现搜索已发送图文及匹配关键字回复的方法
Sep 13 PHP
CentOS7.0下安装PHP5.6.30服务的教程详解
Sep 29 PHP
PHP与Web页面的交互示例详解一
Aug 04 PHP
php5.3后静态绑定用法详解
Nov 11 #PHP
php基于curl实现的股票信息查询类实例
Nov 11 #PHP
PHP中STDCLASS用法实例分析
Nov 11 #PHP
php遍历替换目录下文件指定内容的方法
Nov 10 #PHP
php实现有序数组打印或排序的方法【附Python、C及Go语言实现代码】
Nov 10 #PHP
PHP数组生成XML格式数据的封装类实例
Nov 10 #PHP
Linux平台php命令行程序处理管道数据的方法
Nov 10 #PHP
You might like
PHP中HTTP方式下的Gzip压缩传输方法举偶
2007/02/15 PHP
PHP限制页面只能在微信自带浏览器访问的代码
2014/01/15 PHP
ThinkPHP之N方法实例详解
2014/06/20 PHP
php绘制一个矩形的方法
2015/01/24 PHP
thinkphp框架下404页面设置 仅三步
2016/05/14 PHP
PHP实现的注册,登录及查询用户资料功能API接口示例
2017/06/06 PHP
window.name代替cookie的实现代码
2010/11/28 Javascript
基于jquery的使ListNav兼容中文首字拼音排序的实现代码
2011/07/10 Javascript
30个经典的jQuery代码开发技巧
2014/12/15 Javascript
js控制网页前进和后退的方法
2015/06/08 Javascript
JavaScript必知必会(五) eval 的使用
2016/06/08 Javascript
jQuery实现响应鼠标事件的图片透明效果【附demo源码下载】
2016/06/16 Javascript
json定义及jquery操作json的方法
2016/09/29 Javascript
什么是JavaScript中的结果值?
2016/10/08 Javascript
微信小程序顶部可滚动导航效果
2017/10/31 Javascript
用Node提供静态文件服务的方法
2018/07/06 Javascript
详解vue-cli下ESlint 配置说明
2018/09/03 Javascript
在Vue环境下利用worker运行interval计时器的步骤
2019/08/01 Javascript
JavaScript 面向对象程序设计详解【类的创建、实例对象、构造函数、原型等】
2020/05/12 Javascript
Openlayers测量距离与面积的实现方法
2020/09/25 Javascript
[02:21]DOTA2英雄基础教程 蝙蝠骑士
2013/12/16 DOTA
Python的迭代器和生成器使用实例
2015/01/14 Python
利用python GDAL库读写geotiff格式的遥感影像方法
2018/11/29 Python
Python将string转换到float的实例方法
2019/07/29 Python
Numpy中对向量、矩阵的使用详解
2019/10/29 Python
解决django的template中如果无法引用MEDIA_URL问题
2020/04/07 Python
Pygame框架实现飞机大战
2020/08/07 Python
Python ellipsis 的用法详解
2020/11/20 Python
联想哥伦比亚网上商城:Lenovo Colombia
2017/01/10 全球购物
德国购买踏板车网站:Microscooter
2019/10/14 全球购物
材料物理专业大学毕业生求职信
2013/10/15 职场文书
毕业生求职简历的自我评价
2013/10/23 职场文书
校庆口号
2014/06/20 职场文书
男方婚礼答谢词
2015/01/20 职场文书
《半截蜡烛》教学反思
2016/02/19 职场文书
英国数字版游戏销量周榜公布 《小缇娜的奇幻之地》登顶
2022/04/03 其他游戏