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 相关文章推荐
模拟OICQ的实现思路和核心程序(三)
Oct 09 PHP
PHP XML操作类DOMDocument
Dec 16 PHP
Linux下将excel数据导入到mssql数据库中的方法
Feb 08 PHP
解析php mysql 事务处理回滚操作(附实例)
Aug 05 PHP
使用gd库实现php服务端图片裁剪和生成缩略图功能分享
Dec 25 PHP
ThinkPHP模版中导入CSS和JS文件的方法
Nov 29 PHP
php使用指定字符列表生成随机字符串的方法
Apr 18 PHP
详解WordPress中创建和添加过滤器的相关PHP函数
Dec 29 PHP
php使用PDO从数据库表中读取数据的实现方法(必看)
Jun 02 PHP
PHP中模糊查询并关联三个select框
Jun 19 PHP
PHP5.6.8连接SQL Server 2008 R2数据库常用技巧分析总结
May 06 PHP
gearman管理工具GearmanManager的安装与php使用方法示例
Feb 27 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
Codeigniter注册登录代码示例
2014/06/12 PHP
PHP实现基本留言板功能原理与步骤详解
2020/03/26 PHP
JavaScript表单常用验证集合
2008/01/16 Javascript
document.getElementById为空或不是对象的解决方法
2010/01/24 Javascript
改善你的jQuery的25个步骤 千倍级效率提升
2010/02/11 Javascript
javascript 触发HTML元素绑定的函数
2010/09/11 Javascript
jQuery EasyUI API 中文文档 - NumberBox数字框
2011/10/13 Javascript
js获取php变量的实现代码
2013/08/10 Javascript
Javascript简单实现可拖动的div
2013/10/22 Javascript
JS 去除Array中的null值示例代码
2013/11/20 Javascript
jquery 使用简明教程
2014/03/05 Javascript
JS实现仿QQ效果的三级竖向菜单
2015/09/25 Javascript
手挽手带你学React之React-router4.x的使用
2019/02/14 Javascript
原生js实现抽奖小游戏
2019/06/27 Javascript
NodeJs 实现简单WebSocket即时通讯的示例代码
2019/08/05 NodeJs
Nodejs封装类似express框架的路由实例详解
2020/01/05 NodeJs
vue开发中遇到的问题总结
2020/04/07 Javascript
Javascript实现简易天数计算器
2020/05/18 Javascript
[56:35]DOTA2上海特级锦标赛主赛事日 - 5 总决赛Liquid VS Secret第一局
2016/03/06 DOTA
[01:07:13]TNC vs Pain 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/20 DOTA
python代码制作configure文件示例
2014/07/28 Python
Python中unittest模块做UT(单元测试)使用实例
2015/06/12 Python
使用Python简单的实现树莓派的WEB控制
2016/02/18 Python
Python实现的微信公众号群发图片与文本消息功能实例详解
2017/06/30 Python
python利用MethodType绑定方法到类示例代码
2017/08/27 Python
python基础之包的导入和__init__.py的介绍
2018/01/08 Python
Pycharm设置去除显示的波浪线方法
2018/10/28 Python
Pandas 解决dataframe的一列进行向下顺移问题
2019/12/27 Python
keras 指定程序在某块卡上训练实例
2020/06/22 Python
django前端页面下拉选择框默认值设置方式
2020/08/09 Python
详解html5页面 rem 布局适配方法
2018/01/12 HTML / CSS
怎么处理XML的中文问题
2015/03/26 面试题
老人与海读书笔记
2015/06/26 职场文书
慰问信的写作格式及范文!
2019/06/24 职场文书
MySQL 四种连接和多表查询详解
2021/07/16 MySQL
十大经典日本动漫排行榜 海贼王第三,犬夜叉仅第八
2022/03/18 日漫