今天收到个题目:编写一个在1,2,3,4,5,6,7,8,9(顺序不能变)数字之间插入 + 或- 或什么都不插入,使得计算结果总是100的程序,并输出所有的可能性。例如 1+2+34-5+67-8+9=100; 
一开始在网上找了好久,发现这个问题是在一篇很火的文章《每个程序员1小时内必须解决的5个编程问题》上的第五题 ,如图: 
 
提供一个php的解决方法,如下:

$str = '123456789';
$newStr = '';
function listarr($str, $newStr)
{
if(strlen($str) == 1){
$newStr = $newStr.'9';//最后一位9需要手动加上;
$v = eval("return $newStr;"); //计算公式的结果;
if($v == 100){
echo $newStr."<hr/>";
}
} else {
$newStr .= substr($str, 0, 1);
$str = substr($str,1);
//递归三种可能
listarr($str, $newStr.'+');
listarr($str, $newStr.'-');
listarr($str, $newStr);
}
}
listarr($str, $newStr);

但是要注意,在求和的时候使用的是eval函数,这个函数是非常非常危险的,很多人都说木马就是利用eval函数,所以基本上所有的服务器都会禁用eval的; 
如果不采用eval函数的话,就需要另外写一个方法手动计算公式的值了:

 $str = '123456789';
$newStr = '';
function listarr($str, $newStr)
{
if(strlen($str) == 1){
$newStr = $newStr.'9';//手动加上最后一个9;
$res = cal($newStr);
if($res){
echo $newStr."<hr/>";
}
} else {
$newStr .= substr($str, 0, 1);
$str = substr($str, 1); //递归三种可能
listarr($str, $newStr.'+');
listarr($str, $newStr.'-');
listarr($str, $newStr);
}
function cal($str)
{
$arr = explode('+', $str);//分割数列,储存至数组中
$sum = 0;
foreach($arr as $v){
if(is_numeric($v)){ //判断分割的数组是否为纯数字;
$sum += $v;
} else {
$vArr = explode('-', $v); //对含减号的数组再进行一次分割;
$sum += $vArr[0]; //第一个值前的运算符为+;
unset($vArr[0]);
$s = array_sum($vArr);
$sum -= $s;
}
}
if($sum == 100){
return true;
} else {
return false;
}
}
listarr($str, $newStr);

最后补充一个通用模板

 /**
* $data array 要计算的数列组合;
* $flag array 可用的运算符号
* $result int 要求的和的值
*/
function think_exp($data, $flag, $result)
{
$m = count($data);//m个数字
$n = count($flag);//n个符号
$num = str_split( sprintf ( "%0". ($m - 1) ."d",0) ); //生成一个[0,0,0,0,...,0]的数组
$exp = '';
while($num != 'Ok' ){
$line = '';
for ( $i=0; $i<$m; $i++ ) {
$line .= $data[$i]; //列出所有的式子;
if( isset($num[$i]) ) $line .= $flag[$num[$i]];
}
if ( eval('return '.$line.';') == $result) {
$exp .= $line.'='.$result.'<br />';
}
$num = getNext($num , 0, $n);
}
return $exp;
}
function getNext($next_num , $position = 0, $n){
if ($position == count($next_num)) return 'Ok';
$next_num[$position] = $next_num[$position] + 1;
if ($next_num[$position] < $n) {
return $next_num;
} else {
$next_num[$position] = 0;
return getNext($next_num, $position + 1, $n);
}
}

//计算题目
echo "<font color=red>think_exp(array(1,2,3,4,5,6,7,8,9), array('','+','-','*','/'), 100); </font><br />";
echo think_exp(array(1,2,3,4,5,6,7,8,9), array('','+','-'), 100);
转自Kit_G的博客

PHP方法实现1-9数列中添加‘+’,‘-’或'',使和为100,并输出数列的更多相关文章

  1. ①创建项目testpackage ②在pack2.B中添加方法f ③在类A中添加如下三个成员变量:int型的私有变量i float型的变量f double型的公有变量d 在pack1.B的main方法中为对象a的成员变量f和d分别赋值为2和3 在pack2.C的main方法中为对象a的成员变量d赋值为3

    package pack1; public class A { private int i; float f; public double d; public float getF() { retur ...

  2. mysql 中添加索引的三种方法

    原文:http://www.andyqian.com/2016/04/06/database/mysqleindex/ 在mysql中有多种索引,有普通索引,全文索引,唯一索引,多列索引,小伙伴们可以 ...

  3. Angularjs中添加HighCharts

    一. 添加基本配置 1. 添加指令 angular.module('newApp') .directive('dpHighchart', ['$rootScope', function($rootSc ...

  4. Android5.1 在init.rc 中添加自己的服务【转】

    本文转载自:http://blog.csdn.net/VOlsenBerg/article/details/71085610 我有一个需求就是在Android系统开机的时候把一个配置文件放到Andro ...

  5. 在html中添加script脚本的方法和注意事项

    在html中添加script脚本有两种方法,直接将javascript代码添加到html中与添加外部js文件,这两种方法都比较常用,大家可以根据自己需要自由选择 在html中添加<script& ...

  6. fatal error C1010: 在查找预编译头时遇到意外的文件结尾。是否忘记了向源中添加“#include "StdAfx.h"”? 解决方法

    错误描述: fatal error C1010: 在查找预编译头时遇到意外的文件结尾.是否忘记了向源中添加“#include "StdAfx.h"”? 错误分析:     此错误发 ...

  7. 在keil 4中添加stc系列芯片的方法--【sky原创】

    在keil 4中添加stc系列芯片的方法: 1.从官网下载uv3.cdb的文件网址是:http://www.stcmcu.com/ 2.下载好后把uv3.cdb文件改成STC.cdb:3. 然后将[S ...

  8. 在TC(Total Commander)中添加启动Cygwin快捷键的方法

    在TC(Total Commander)中添加启动Cygwin快捷键的方法 1.在Cygwin的安装目录下,增加文件tc-cygwin.bat(例如C:\cygwin-177\tc-cygwin.ba ...

  9. Visio中添加、移动或删除形状上的连接点的方法

    Visio中添加.移动或删除形状上的连接点的方法 利用Visio画图时,学会使用连接点能使你的画图质量和速度大幅度提高.下面在Visio2010中,以一个例子讲述如何使用连接点. 一. 准备 1. 打 ...

随机推荐

  1. PHP实现水印效果(文字、图片)

    第一种 <?php /** * 功能:给一张图片加上水印效果 * $i 要加水印效果的图片 * $t 水印文字 * $size 文字大小 * $pos 水印的位置 * $color 文字的颜色 ...

  2. 各种语系的unicode对应以及local编码方式

    链接:http://www.doc88.com/p-801578373970.html 一.英文 Unicode范围: 0041-005A, 0061-007A (若含数字与符号,则为0021-007 ...

  3. 理解Activity.runOnUiThread()

    这是一篇译文(中英对照),原文链接:Understanding Activity.runOnUiThread() When developing Android applications we alw ...

  4. Acm弱校奋斗史

    我也是来自弱校的,没有教练,甚至老师都不理我们这种Acmer.看完这篇文章感触颇深. 原文链接 http://acmicpc.info/archives/369 原文 题解:还记得2年前的一个晚上,我 ...

  5. MyEclipse中如何去掉JS/JSP语法错误提示

    一    优化一下MyEclipse 1 .关闭MyEclipse的自动validation      windows > perferences > myeclipse > val ...

  6. JavaScript预编译原理分析

    一直对变量对象,活动对象,预编译,变量提升,执行上下文的时间顺序有着凌乱的认识,但是这些对理解JS语法有着很重要的作用.读了很多人的文章,都没有一个特别清晰的把这些写出来. 今天主要总结一下现阶段自己 ...

  7. WPF将RGB转为HSL的工具类

    class HSLColor     {         private int _alpha = 255;         public int _hue = 0;         public d ...

  8. 用Node.JS+MongoDB搭建个人博客(页面模板)(五)(结束)

    <差不多先生> 我是差不多先生,我的差不多是天生.也代表我很天真,也代表我是个闲人.这差不多的人生,总是见缝插针. 求学的道路上总是孤独的,即使别人不理解我,认为我是奇葩!但没关系,我会坚 ...

  9. 通过grub-install命令把grub安装到u盘-总结

    通过grub-install命令把grub安装到u盘 ①准备一个u盘,容量不限,能有1MB都足够了. ②把u盘格式化(我把u盘格式化成FAT.fat32格式了,最后证明也是成功的).③开启linux系 ...

  10. 利用squid 反向代理提高网站性能

    部分转自:http://www.ibm.com/developerworks/cn/linux/l-cn-squid/ Squid 反向代理的实现原理 目前有许多反向代理软件,比较有名的有 Nginx ...