php经典趣味算法实例代码


Posted in PHP onJanuary 21, 2020

1、一群猴子排成一圈,按1,2,…,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去…,如此不停的进行下去,直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n, 输出最后那个大王的编号。

function king($n, $m){
  $monkeys = range(1, $n);     //创建1到n数组
  $i=0;
  while (count($monkeys)>1) {  //循环条件为猴子数量大于1
    if(($i+1)%$m==0) {  //$i为数组下标;$i+1为猴子标号
      unset($monkeys[$i]);  //余数等于0表示正好第m个,删除,用unset删除保持下标关系
    } else {
      array_push($monkeys,$monkeys[$i]);   //如果余数不等于0,则把数组下标为$i的放最后,形成一个圆形结构
      unset($monkeys[$i]);
    }
      $i++;//$i 循环+1,不断把猴子删除,或 push到数组 
  }
  return current($monkeys);  //猴子数量等于1时输出猴子标号,得出猴王
}
echo king(6,3);

2、有一母牛,到4岁可生育,每年一头,所生均是一样的母牛,到15岁绝育,不再能生,20岁死亡,问n年后有多少头牛。

function niu($y){
  static $num= 1;         //定义静态变量;初始化牛的数量为1
  for ($i=1; $i <=$y ; $i++) {   
    if($i>=4 && $i<15){     //每年递增来算,4岁开始+1,15岁不能生育
    $num++;
      niu($y-$i);       //递归方法计算小牛$num,小牛生长年数为$y-$i
    }else if($i==20){      
    $num--;             //20岁死亡减一
    }
  return $num;
}
}

3、杨辉三角

<?php
/* 默认输出十行,用T(值)的形式可改变输出行数 */
class T{
 private $num;
 public function __construct($var=10) {
  if ($var<3) die("值太小啦!");
  $this->num=$var;
 }
 public function display(){
  $n=$this->num;
  $arr=array();
 //$arr=array_fill(0,$n+1,array_fill(0,$n+1,0));
  $arr[1]=array_fill(0,3,0);
  $arr[1][1]=1;
  echo str_pad(" ",$n*12," ");
  printf("%3d",$arr[1][1]);
  echo "<br/>";
  for($i=2;$i<=$n;$i++){
   $arr[$i]=array_fill(0,($i+2),0);
   for($j=1;$j<=$i;$j++){
    if($j==1)
     echo str_pad(" ",($n+1-$i)*12," ");
    printf("%3d",$arr[$i][$j]=$arr[$i-1][$j-1]+$arr[$i-1][$j]);
    echo " ";
   }
   echo"<br/>";
  }
 }
}
$yh=new T('3'); //$yh=new T(数量);
$yh->display();
?>

4.冒泡排序

function maopao($arr){
  $len = count($arr); 
  for($k=0;$k<=$len;$k++)
  {
    for($j=$len-1;$j>$k;$j--){
     if($arr[$j]<$arr[$j-1]){
      $temp = $arr[$j];
      $arr[$j] = $arr[$j-1];
      $arr[$j-1] = $temp;
     }
    }
  }
  return $arr;
}

5.快速排序

function quickSort($arr) {
  //先判断是否需要继续进行
  $length = count($arr);
  if($length <= 1) {
    return $arr;
  }
  //选择第一个元素作为基准
  $base_num = $arr[0];
  //遍历除了标尺外的所有元素,按照大小关系放入两个数组内
  //初始化两个数组
  $left_array = array(); //小于基准的
  $right_array = array(); //大于基准的
  for($i=1; $i<$length; $i++) {
    if($base_num > $arr[$i]) {
      //放入左边数组
      $left_array[] = $arr[$i];
    } else {
      //放入右边
      $right_array[] = $arr[$i];
    }
  }
  //再分别对左边和右边的数组进行相同的排序处理方式递归调用这个函数
  $left_array = quickSort($left_array);
  $right_array = quickSort($right_array);
  //合并
 
  return array_merge($left_array, array($base_num), $right_array);
}

6.二分查找算法(折半查找算法)

function binsearch($x,$a){
  $c=count($a);
  $lower=0;
  $high=$c-1;
  while($lower<=$high){
    $middle=intval(($lower+$high)/2);
    if($a[$middle]>$x){
      $high=$middle-1;
    } elseif($a[$middle]<$x){
      $lower=$middle+1;
    } else{
      return $middle;
    }
  }
  return false;
}

7.PHP奇异算法

<?php
function test(){
 $a=1;
 $b=&$a;
 echo (++$a)+(++$a);
}
test();

PHP7以下的版本返回的是 6,PHP7版本返回5 ,还真的算奇异,个人底层算法差,认为是PHP7以下版本的BUG

8.字符集合:输入一个字符串,求出该字符串包含的字符集合,并按顺序排序(英文)

function set($str){
  //转化为数组
  $arr = str_split($str);
  //去除重复
  $arr = array_flip(array_flip($arr));
  //排序
  sort($arr);
  //返回字符串
  return implode('', $arr);
}

9.遍历一个文件下的所有文件和子文件夹下的文件

function AllFile($dir){
  if($dh = opendir($dir)){
    while (($file = readdir($dh)) !== false){
      if($file !='..' && $file !='.'){
        if(is_dir($dir.'/'.$file)){
          AllFile($dir.'/'.$file);  //如果判断还是文件,则递归
        }else{ 
          echo $file;     //输出文件名
        }
      }
    } 
  }
}

10.从一个标准的Url提取出文件的扩展名

function getExt($url)
 {
  $arr = parse_url($url);
  $file = basename($arr['path']);// basename函数返回路径中的文件名部分
  $ext = explode('.', $file);
  return $ext[count($ext)-1];
 }

11.有个人想上一个n级的台阶,每次只能迈1级或者迈2级台阶,问:这个人有多少种方法可以把台阶走完?例如:总共3级台阶,可以先迈1级再迈2级,或者先迈2级再迈1级,或者迈3次1级总共3中方式

function jieti($num){  //实际上是斐波那契数列
    return $num<2?1:jieti($num-1)+jieti($num-2);
  }

12.请写一段PHP代码,确保多个进程同时写入同一个文件成功

<?php
  $fp = fopen("lock.txt","w+");
  if (flock($fp,LOCK_EX)) {
    //获得写锁,写数据
    fwrite($fp, "write something");
 
    // 解除锁定
    flock($fp, LOCK_UN);
  } else {
    echo "file is locking...";
  }
  fclose($fp);
?>

13.无限级分类

function tree($arr,$pid=0,$level=0){
    static $list = array();
    foreach ($arr as $v) {
      //如果是顶级分类,则将其存到$list中,并以此节点为根节点,遍历其子节点
      if ($v['pid'] == $pid) {
        $v['level'] = $level;
        $list[] = $v;
        tree($arr,$v['id'],$level+1);
      }
    }
    return $list;
  }

14.获取上个月第一天 和 最后一天

//获取上个月第一天
  date('Y-m-01',strtotime('-1 month'));
 
  //获取上个月最后一天
  date('Y-m-t',strtotime('-1 month'));

15.随机输入一个数字能查询到对应的数据区间

//把区间换成数组写法,用二分法查找区间
  function binsearch($x,$a){ 
    $c=count($a); 
    $lower=0; 
    $high=$c-1; 
    while($lower<=$high){ 
      $middle=intval(($lower+$high)/2); 
      if($a[$middle]>=$x){ 
        $high=$middle-1;
      }elseif($a[$middle]<=$x ){ 
        $lower=$middle+1;
      }  
    }
 
    return '在区间'.$a[$high].'到'.$a[$lower]; 
  }
 
  $array = ['1','50','100','150','200','250','300'];
  $a = '120';
  echo binsearch($a,$array);

以上就是php经典趣味算法的详细内容,更多内容请关注三水点靠木以前发布的文章。

PHP 相关文章推荐
ASP知识讲座四
Oct 09 PHP
一些常用的php函数
Dec 06 PHP
PHP 批量删除 sql语句
Jun 05 PHP
理解php Hash函数,增强密码安全
Feb 25 PHP
PHP 冒泡排序 二分查找 顺序查找 二维数组排序算法函数的详解
Jun 25 PHP
PHP 文件编程综合案例-文件上传的实现
Jul 03 PHP
php 获取今日、昨日、上周、本月的起始时间戳和结束时间戳的方法
Sep 28 PHP
php5.3 不支持 session_register() 此函数已启用的解决方法
Nov 12 PHP
php中3种方法删除字符串中间的空格
Mar 10 PHP
为你总结一些php信息函数
Oct 21 PHP
Zend Framework教程之Zend_Layout布局助手详解
Mar 04 PHP
一个简单的php MVC留言本实例代码(必看篇)
Sep 22 PHP
php利用ZipArchive类操作文件的实例
Jan 21 #PHP
Laravel 手动开关 Eloquent 修改器的操作方法
Dec 30 #PHP
Laravel 集成微信用户登录和绑定的实现
Dec 27 #PHP
PHP单元测试配置与使用方法详解
Dec 27 #PHP
PHP全局使用Laravel辅助函数dd
Dec 26 #PHP
解决php用mysql方式连接数据库出现Deprecated报错问题
Dec 25 #PHP
PHP高并发和大流量解决方案整理
Dec 24 #PHP
You might like
PHP4实际应用经验篇(9)
2006/10/09 PHP
PHP 应用程序的安全 -- 不能违反的四条安全规则
2006/11/26 PHP
ajax缓存问题解决途径
2006/12/06 PHP
phpmyadmin MySQL 加密配置方法
2009/07/05 PHP
超详细的php用户注册页面填写信息完整实例(附源码)
2015/11/17 PHP
PHP闭包函数传参及使用外部变量的方法
2016/03/15 PHP
Yii2实现多域名跨域同步登录退出
2017/02/04 PHP
PHP cookie,session的使用与用户自动登录功能实现方法分析
2019/06/05 PHP
Laravel 5.5 实现禁用用户注册示例
2019/10/24 PHP
一个原生的用户等级的进度条
2010/07/03 Javascript
js内置对象 学习笔记
2011/08/01 Javascript
JS连接SQL数据库与ACCESS数据库的方法实例
2013/11/21 Javascript
JavaScript Math.ceil() 函数使用介绍
2013/12/11 Javascript
JavaScript的作用域和块级作用域概念理解
2014/09/21 Javascript
Javascript数组操作函数总结
2015/02/05 Javascript
jQuery中extend函数详解
2015/02/13 Javascript
JQuery 封装 Ajax 常用方法(推荐)
2017/05/21 jQuery
vue中实现methods一个方法调用另外一个方法
2018/02/08 Javascript
webpack4 optimization使用总结
2019/11/10 Javascript
[46:53]Secret vs Liquid 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
Python写的一个简单DNS服务器实例
2014/06/04 Python
Python通过调用mysql存储过程实现更新数据功能示例
2018/04/03 Python
Python函数和模块的使用总结
2019/05/20 Python
python中count函数简单的实例讲解
2020/02/06 Python
利用Python实现Excel的文件间的数据匹配功能
2020/06/16 Python
中国京东和泰国中央集团合资的网站:JD CENTRAL
2020/08/22 全球购物
中专生职业生涯规划书范文
2014/01/10 职场文书
村长贪污检举信
2014/04/04 职场文书
2014年新生军训方案
2014/05/01 职场文书
意外伤害赔偿协议书
2014/09/16 职场文书
债务追讨授权委托书范本
2014/10/16 职场文书
基层党员学习党的群众路线教育实践活动心得体会
2014/11/04 职场文书
工艺技术员岗位职责
2015/02/04 职场文书
2019年亲子运动会口号
2019/10/11 职场文书
教你用Python爬取英雄联盟皮肤原画
2021/06/13 Python
python生成可执行exe控制Microsip自动填写号码并拨打功能
2021/06/21 Python