我的编程空间,编程开发者的网络收藏夹
学习永远不晚

php算法面试题及答案示例的分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

php算法面试题及答案示例的分析

这篇文章将为大家详细讲解有关php算法面试题及答案示例的分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

php有什么用

php是一个嵌套的缩写名称,是英文超级文本预处理语言,它的语法混合了C、Java、Perl以及php自创新的语法,主要用来做网站开发,许多小型网站都用php开发,因为php是开源的,从而使得php经久不衰。

题目一:

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

function king($m, $n) {if (1 >= $n) {return $n;}$monkeys = range(1, $n);$count = $n;while ($count > 1) {$remainder = $m % $count;unset($monkeys[$remainder - 1]);$monkeys = array_values($monkeys);$count--;}return array_shift($monkeys);}

题目二:

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

function cows ($n) {$cows = [1];for ($i = 1; $i <= $n; $i++) {// 新出生的牛$new_number = 0;foreach ($cows as $age => $num) {// 4岁到14岁的牛生育新的母牛if ($age >= 3 &&$age <= 13) {$new_number += $num;}}// 将新出生的牛加到数组开头array_unshift($cows, $new_number);// 取出数组的前20个单元$cows = array_slice($cows, 0, 20);}return array_sum($cows);}

题目三:

冒泡排序

function bubble_sort ($array) {$array = array_values($array);for ($i = 0; $i < count($array); $i++) {for ($j = 0;$j < count($array) - $i - 1; $j++) {if ($array[$j] > $array[$j + 1]) {$temp = $array[$j + 1];$array[$j + 1] = $array[$j];$array[$j] = $temp;}}}return $array;}

题目四:

快速排序

function quick_sort ($array) {if (count($array) <= 1) {return $array;}$left_array = [];$right_array = [];$key = array_shift($array);foreach ($array as $value) {if ($key > $value) {$left_array[] = $value;} else {$right_array[] = $value;}}return array_merge(quick_sort($left_array), [$key], quick_sort($right_array));}

(学习视频分享:php视频教程)

题目五:

选择排序

function select_sort ($array) {$sort_array = [];while (count($array)) {$min = null;$min_key = null;foreach ($array as $key => $value) {if (is_null($min)) {$min = $value;$min_key = $key;} elseif ($min > $value) {$min = $value;$min_key = $key;}}$sort_array[] = $min;unset($array[$min_key]);}return $sort_array;}

题目六:

字符集合:输入一个字符串,求出该字符串包含的字符集合,并按顺序排序

function unique_char ($str) {$arr = array_unique(str_split($str));sort($arr);return implode('', $arr);}

题目七:

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

function all_file ($dir) {if (is_dir($dir)) {$resource = opendir($dir);while ($file = readdir($resource)) {if (in_array($file, ['.', '..'])) {continue;} elseif (is_dir($dir . '/' . $file)) {all_file($dir . '/' . $file);} else {echo $dir . '/' . $file, "\n";}}} else {echo $dir, "\n";}}

题目八:

有个人想上一个n级的台阶,每次只能迈1级或者迈2级台阶,问:这个人有多少种方法可以把台阶走完?例如:总共3级台阶,可以先迈1级再迈2级,或者先迈2级再迈1级,或者迈3次1级总共3中方式.(实际上是斐波那契数列)

function ladder($steps) {return $steps <2 ? 1 : ladder($steps - 1) + ladder($steps - 2);}

题目九:

遍历二叉树

class Node {public $value;public $left;public $right;}function preorder ($root) {echo $root->value;if (!empty($root->left)) {preorder($root->left);}if (!empty($root->right)) {preorder($root->right);}}function inorder ($root) {if (!empty($root->left)) {inorder($root->left);}echo $root->value;if (!empty($root->right)) {inorder($root->right);}}function tailorder ($root) {if (!empty($root->left)) {tailorder($root->left);}if (!empty($root->right)) {tailorder($root->right);}echo $root->value;}$d = new Node;$d->value = 'D';$b = new Node;$b->value = 'B';$b->left = $d;$e = new Node;$e->value = 'E';$f = new Node;$f->value = 'F';$c = new Node;$c->value = 'C';$c->left = $e;$c->right = $f;$a = new Node;$a->value = 'A';$a->left = $b;$a->right = $c;preorder($a);echo "\n";inorder($a);echo "\n";tailorder($a);echo "\n";

关于“php算法面试题及答案示例的分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

php算法面试题及答案示例的分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

php算法面试题及答案示例的分析

这篇文章将为大家详细讲解有关php算法面试题及答案示例的分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。php有什么用php是一个嵌套的缩写名称,是英文超级文本预处理语言,它的语法混合了C、Java、P
2023-06-06

webpack面试题及答案实例分析

这篇“webpack面试题及答案实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“webpack面试题及答案实例分析”文
2023-07-05

C#算法面试题的示例分析

这篇文章主要为大家展示了“C#算法面试题的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C#算法面试题的示例分析”这篇文章吧。C#算法一道面试题:程序设计: 猫大叫一声,所有的老鼠都开始
2023-06-18

Java面试题之算法的示例分析

小编给大家分享一下Java面试题之算法的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!面试题1:你说一下常用的排序算法都有哪些?追问1:谈一谈你对快排的理
2023-06-20

PHP面试题的示例分析

这篇文章主要介绍了PHP面试题的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一 、PHP基础部分1、PHP语言的一大优势是跨平台,什么是跨平台?PHP的运行环境最优
2023-06-15

软考案例分析题的通用答题方法!附2023软考案例分析题及答案解析

  案例分析的通用答题方法,这个适用于软考高级科目-信息系统项目管理师,也可用于软考中级科目-系统集成项目管理工程师。以下看法仅供参考,具体情况考题需要根据考题具体分析。  一、历年考试范围  首先,范围管理、进度管理、成本管理、质量管理,这4大管理都是历年考试的大头,所以全拿下这些对考试的通过有很大帮助。  另外,配
软考案例分析题的通用答题方法!附2023软考案例分析题及答案解析
2024-04-19

Java面试题之手撸算法的示例分析

这篇文章将为大家详细讲解有关Java面试题之手撸算法的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。手撸算法1:查找数组中重复元素和重复元素的个数当听让我写这个算法时,纸笔还没给到我手上,作为一个
2023-06-20

20+值得了解的PHP面试题(附答案分析)

本篇文章给大家分享20多个PHP面试题,查漏补缺,带你巩固一波地基,看看你能答对几个?希望对大家有所帮助。Q1: == 和 === 之间有什么区别?话题: PHP困难: ⭐如果是两个不同的类型,运算符==则在两个不同的类型之间进行强制转换===操作符执行’类型安全比较‘这意味着只有当两个操作数具有相同的类型和相同的值时,它才会返回TRUE。1 === 1: true1 == 1: true1 ===
2022-06-14

PHP基础面试题的示例分析

这篇文章给大家分享的是有关PHP基础面试题的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、什么事面向对象?主要特征是什么? 面向对象是程序的一种设计方式,它利于提高程序的重用性,使程序结构更加清晰。主
2023-06-15

PHP面试题之选择题的示例分析

这篇文章主要介绍PHP面试题之选择题的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 1. 得到的输出是什么A.空 B.true C.false
2023-06-14

python算法题的示例分析

这篇文章将为大家详细讲解有关python算法题的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。题目描述:编写一个算法来确定一个数字是否“快乐”。 快乐的数字按照如下方式确定:从一个正整数开始,用其
2023-06-15

Java面试题之JVM的示例分析

这篇文章给大家分享的是有关Java面试题之JVM的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。面试题1:你遇到过哪些OOM情况,什么原因造成的?怎么解决的?该问题主要针对你遇到的实际问题出发,可以根据你
2023-06-20

Java面试题之分布式的示例分析

这篇文章主要为大家展示了“Java面试题之分布式的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Java面试题之分布式的示例分析”这篇文章吧。面试题1:说说什么分布式事务?解释一下什么是
2023-06-20

java二叉树面试题的示例分析

小编给大家分享一下java二叉树面试题的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!二叉树的深度题目:输入一颗二叉树的根节点,求该树的的深度。输入一颗二
2023-06-20

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录