【来自媳妇的需求】PHP实现随机数和方程求解
话说2015.11.06 ,北京下了第一场雪。16年的今天没下雪,但是雾霾还是不小的,帮媳妇整理她工作时,出现了下面的需求,便想到使用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($data as $key)
{/*{{{*/
echo "处理 {$key}\n";
$resX = createX($key);
foreach($resX as $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";
return array($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";
return array(round($m0/1000, 4), round($m1/1000, 4), round($m2/1000, 4)); }/*}}}*/ ?>
【遇到的问题和不足之处】
1. 【数组key值不能相同】开始遇到的是 得到的平均数的原始三个值有可能有相同的,但是数组中的key是不能相同的,于是做了处理。
同时,key值做了 string的转化
2. 【小数处理】还有就是 因为涉及的是 4位的小数,循环遍历,满足条件输出不方便,就 乘以1000扩大倍数,最后再除以1000还原。
3. 【媳妇新的要求。。】最后就是 因为媳妇的需求还是会变化的,希望我 做成app性质的,这样她可以安装后,自己可以随时使用,
但是对于我这只懂PHP的猿来说,爱莫能助,最多就是 申请阿里云,搭建服务器,根据她变化的需求,服务端修改程序,web访问就不错了,汗
【来自媳妇的需求】PHP实现随机数和方程求解的更多相关文章
- 【转】来自《轻松scrum之旅》的敏捷开发总结
敏捷开发的核心价值观是,软件开发最重要的是给用户提供有价值的.可以工作的软件.如何保证提供有价值的软件,是通过反馈机制来完成的.这一点,我们体会很深.自从采用敏捷开发以后,我们比以前更有意识地希望得到 ...
- JavaScript实现生成指定范围随机数和一个包含不重复数的随机数组
目前JavaScript里面还没有现成的方法可以实现这个简单地需求,我们就需要自己写代码了. 在js中有个函数:Math.random() 这个函数可以生成 [0,1) 的一个随机数. 我们的简单的改 ...
- LoadRunner随机数
需求:自定义随机数 方法: int randomnumber; randomnumber = rand()%+; //100到300的随机数 lr_output_message("ca:%d ...
- .NET平台机器学习资源汇总,有你想要的么?
接触机器学习1年多了,由于只会用C#堆代码,所以只关注.NET平台的资源,一边积累,一边收集,一边学习,所以在本站第101篇博客到来之际,分享给大家.部分用过的 ,会有稍微详细点的说明,其他没用过的, ...
- .NET平台机器学习
.NET平台机器学习资源汇总,有你想要的么? 接触机器学习1年多了,由于只会用C#堆代码,所以只关注.NET平台的资源,一边积累,一边收集,一边学习,所以在本站第101篇博客到来之际,分享给大家.部分 ...
- .NET平台机器学习资源汇总,有你想要的么?(转)
出处:http://www.cnblogs.com/asxinyu/p/4422050.html 阅读目录 1.开源综合类 2.开源.NET平台非综合类 3.其他资源与技术博客 4.我的100篇博客之 ...
- 个人对sort()排序方法中比较函数一直很混乱,今日理清
需求:使用随机数来打印出0-10,并排序. 代码: var a = new Array();var testArray = function() { while (1) { var b = parse ...
- LoadRunner录制图片验证码
LoadRunner录制图片验证码 LoadRunner自身是无法捕获到图片验证码的,但是我们可以帮助LoadRunner来实现验证码的捕获. 1.图片验证码 图片验证码的产生来自服务器端,由服务器生 ...
- 常用SQL语句(工作)
1. 经销商 按店铺交易量汇总 ) from bp_shop_info i left join ( select t.shop_id,sum(t.shop_cost) as summary from ...
随机推荐
- CWR Mobile简介
原创地址:http://www.cnblogs.com/jfzhu/p/4266671.html 转载请注明出处 (一)CWR公司背景 Dynamics CRM除了自己Out of Box对移动设备的 ...
- C++ 回调函数 实现 的测试代码
最近项目里使用了异步Socket,使用的是完成端口做的e; Accept,receive,send 等完全的异步实现(多线程) 然后 又要多个端口使用, 后来想到包装下完成端口Socket,然后当有事 ...
- 程序中保存状态的方式之Cookies
程序中保存状态的方式之 Cookies,之前写过一篇关于ViewState的.现在继续总结Cookies方式的 新建的测试页面login <%@ Page Language="C#&q ...
- jquery中on/delegate的原理
jquery中on/delegate的原理 早期版本中叫delegate, 后来有过live函数,再后来统一用on.下面的方法等效: // jQuery 1.3 $(selector).(events ...
- 无法在“EntityFramework”已存在的情况下创建影像复制该文件的解决方案
问题产生的原因:你项目正在生成中你就打开浏览器预览了,导致这个问题解决方案:右击重新生成项目,等生成后再打开 “/”应用程序中的服务器错误. 无法在“EntityFramework”已存在的情况下创建 ...
- C# 如何提取SaveFileDialog的保存路径
直接上代码 public TestOne() { InitializeComponent(); SaveFileDialog();//调用打开SaveFileDialog 保存对话框 } #regio ...
- 学用MVC4做网站六后台管理:6.1管理员(续)
接6.1 首先在~/Areas/Admin/Models文件夹添加管理员模型Administrator.cs using System.ComponentModel.DataAnnotations; ...
- 深入理解DOM事件机制系列第一篇——事件流
× 目录 [1]历史 [2]事件冒泡 [3]事件捕获[4]事件流 前面的话 javascript操作CSS称为脚本化CSS,而javascript与HTML的交互是通过事件实现的.事件就是文档或浏览器 ...
- OracleDBA之数据库管理
以下这些东西是我的麦库上存的当时学Oracle的学习笔记今天拿出来和大家分享一下,转载请注明出处,下面用的Oracle的版本是10g,用的时WinServer2003的操作系统,可能有些命令和Orac ...
- (转)使用minicpan创建本地CPAN
在临时的办公场所网络不畅,有时不能下载cpan上的软件包,所有只能自建一个cpan. 这里使用了工具'minicpan',简单地说:就是把互联网上的CPAN搬到自己的电脑里,它的最初想法来自Randa ...