您当前的位置:首页 > 电脑百科 > 程序开发 > 算法

php经典趣味算法

时间:2019-07-31 11:49:15  来源:  作者:

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);



Tags:php 算法   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
PHP近期常见算法面试题面试的时候会经常问到一些算法题,算法题的考察主要考察的是基础知识的掌握程度和逻辑思考能力以及学习能力的考察,所以什么样的算法题是容易考到的呢?一...【详细内容】
2020-08-10  Tags: php 算法  点击:(231)  评论:(0)  加入收藏
1、一群猴子排成一圈,按1,2,&hellip;,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去&hellip;,如此不停的进行下去,直到最后只剩下一...【详细内容】
2019-07-31  Tags: php 算法  点击:(211)  评论:(0)  加入收藏
▌简易百科推荐
前言Kafka 中有很多延时操作,比如对于耗时的网络请求(比如 Produce 是等待 ISR 副本复制成功)会被封装成 DelayOperation 进行延迟处理操作,防止阻塞 Kafka请求处理线程。Kafka...【详细内容】
2021-12-27  Java技术那些事    Tags:时间轮   点击:(1)  评论:(0)  加入收藏
博雯 发自 凹非寺量子位 报道 | 公众号 QbitAI在炼丹过程中,为了减少训练所需资源,MLer有时会将大型复杂的大模型“蒸馏”为较小的模型,同时还要保证与压缩前相当的结果。这就...【详细内容】
2021-12-24  量子位    Tags:蒸馏法   点击:(11)  评论:(0)  加入收藏
分稀疏重建和稠密重建两类:稀疏重建:使用RGB相机SLAMOrb-slam,Orb-slam2,orb-slam3:工程地址在: http://webdiis.unizar.es/~raulmur/orbslam/ DSO(Direct Sparse Odometry)因为...【详细内容】
2021-12-23  老师明明可以靠颜值    Tags:算法   点击:(7)  评论:(0)  加入收藏
1. 基本概念希尔排序又叫递减增量排序算法,它是在直接插入排序算法的基础上进行改进而来的,综合来说它的效率肯定是要高于直接插入排序算法的;希尔排序是一种不稳定的排序算法...【详细内容】
2021-12-22  青石野草    Tags:希尔排序   点击:(6)  评论:(0)  加入收藏
ROP是一种技巧,我们对execve函数进行拼凑来进行system /bin/sh。栈迁移的特征是溢出0x10个字符,在本次getshell中,还碰到了如何利用printf函数来进行canary的泄露。ROP+栈迁移...【详细内容】
2021-12-15  星云博创    Tags:栈迁移   点击:(22)  评论:(0)  加入收藏
一、什么是冒泡排序1.1、文字描述冒泡排序是一种简单的排序算法。它重复地走访要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地...【详细内容】
2021-12-15    晓掌柜丶韶华  Tags:排序算法   点击:(16)  评论:(0)  加入收藏
在了解golang的map之前,我们需要了解哈希这个概念。哈希表,又称散列表(Hash table),是根据键(key)而直接访问在内存储存位置的数据结构。也就是说,它通过计算出一个键值的函数,将...【详细内容】
2021-12-07  一棵梧桐木    Tags:哈希表   点击:(14)  评论:(0)  加入收藏
前面文章在谈论分布式唯一ID生成的时候,有提到雪花算法,这一次,我们详细点讲解,只讲它。SnowFlake算法据国家大气研究中心的查尔斯&middot;奈特称,一般的雪花大约由10^19个水分子...【详细内容】
2021-11-17  小心程序猿QAQ    Tags:雪花算法   点击:(24)  评论:(0)  加入收藏
导读:在大数据时代,对复杂数据结构中的各数据项进行有效的排序和查找的能力非常重要,因为很多现代算法都需要用到它。在为数据恰当选择排序和查找策略时,需要根据数据的规模和类型进行判断。尽管不同策略最终得到的结果完...【详细内容】
2021-11-04  华章科技    Tags:排序算法   点击:(40)  评论:(0)  加入收藏
这是我在网上找的资源的一个总结,会先给出一个我看了觉得还行的关于算法的讲解,再配上实现的代码: Original author: Bill_Hoo Original Address: http://blog.sina.com.cn/s/bl...【详细内容】
2021-11-04  有AI野心的电工和码农    Tags: KMP算法   点击:(36)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条