iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >php算法面试题及答案示例的分析
  • 570
分享到

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

2023-06-06 17:06:48 570人浏览 八月长安
摘要

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

这篇文章将为大家详细讲解有关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算法面试题及答案示例的分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: php算法面试题及答案示例的分析

本文链接: https://www.lsjlt.com/news/248087.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • php算法面试题及答案示例的分析
    这篇文章将为大家详细讲解有关php算法面试题及答案示例的分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。php有什么用php是一个嵌套的缩写名称,是英文超级文本预处理语言,它的语法混合了C、Java、P...
    99+
    2023-06-06
  • php算法面试题及答案
    PHP的基础知识点 PHP中类的继承属于单继承,一个子类只能继承一个父类。可见性为public protected的属性和方法可以被继承。 继承的方法或属性可以被重写,可见性越来越大。 PHP中的变量名区分大小写,但类名、函数名不区分大小...
    99+
    2023-08-31
    php 服务器 开发语言
  • webpack面试题及答案实例分析
    这篇“webpack面试题及答案实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“webpack面试题及答案实例分析”文...
    99+
    2023-07-05
  • php面试题及答案
    1 请输出下面代码执行结果 答案:1 复制 讲解:count(var)是用来统计数组或对象的元素个数的。当var是null或者空数组时,结果为0。如果var是普通变量,则返回1。正常情况下返回var中的元素或属性个数。 2 请说明ph...
    99+
    2023-09-10
    php 开发语言
  • C#算法面试题的示例分析
    这篇文章主要为大家展示了“C#算法面试题的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C#算法面试题的示例分析”这篇文章吧。C#算法一道面试题:程序设计: 猫大叫一声,所有的老鼠都开始...
    99+
    2023-06-18
  • PHP面试题汇总及答案
    PHP程序员经典面试问题 1、PHP的意思,它能干些什么 PHP是一个基于服务端来创建动态网站的脚本语言,您可以用PHP和HTML生成网站主页,英文的全称(Professional Home Pages) (1)WEB开发、实现订单、网络通...
    99+
    2023-08-31
    php 开发语言
  • 百度php面试题及答案
    基础题: 1.表单中 get与post提交方法的区别 答:get是发送请求HTTP协议通过url参数传递进行接收,而post是实体数据,可以通过表单提交大量信息. session与cookie的区别 答:session:储存用户访问的全局唯...
    99+
    2023-10-01
    php 数据库 开发语言
  • Java面试题之算法的示例分析
    小编给大家分享一下Java面试题之算法的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!面试题1:你说一下常用的排序算法都有哪些?追问1:谈一谈你对快排的理...
    99+
    2023-06-20
  • PHP面试题的示例分析
    这篇文章主要介绍了PHP面试题的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一 、PHP基础部分PHP语言的一大优势是跨平台,什么是跨平台?PHP的运行环境最优搭配...
    99+
    2023-06-15
  • PHP有哪些面试题及答案
    今天小编给大家分享一下PHP有哪些面试题及答案的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、什么事面向对象?主要特征是什...
    99+
    2023-07-02
  • 云计算面试题及答案,云计算岗位精品面试题
    云计算现在发展前景很好,很多人都会选择云计算。但是学完云计算如何面试成功也是重要的一环。这次在本文就为大家带来云计算面试及答案,希望能够对大家找工作的征程有所助益。针对云计算工程师,现在业内也有不少开放认证的公司,比如AWS、Azure、M...
    99+
    2023-06-04
  • Java面试题之手撸算法的示例分析
    这篇文章将为大家详细讲解有关Java面试题之手撸算法的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。手撸算法1:查找数组中重复元素和重复元素的个数当听让我写这个算法时,纸笔还没给到我手上,作为一个...
    99+
    2023-06-20
  • 20道必备!PHP面试题及详细答案解析
    当今互联网时代,PHP已经成为一种广泛使用的服务器端脚本语言。如果您正在准备PHP的面试,那么您需要了解一些常见的PHP面试题。在本篇博客中,我们将提供20道常见的PHP面试题及其答案。 什么是PHP? 答:PHP是一种广泛使用的服务器端脚...
    99+
    2023-09-01
    php 开发语言 数据库
  • PHP基础面试题的示例分析
    这篇文章给大家分享的是有关PHP基础面试题的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、什么事面向对象?主要特征是什么? 面向对象是程序的一种设计方式,它利于提高程序的重用性,使程序结构更加清晰。主...
    99+
    2023-06-15
  • 分享有关spring boot面试题及答案
    这篇文章主要介绍“分享有关spring boot面试题及答案”,在日常操作中,相信很多人在分享有关spring boot面试题及答案问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解...
    99+
    2024-04-02
  • PHP面试题之选择题的示例分析
    这篇文章主要介绍PHP面试题之选择题的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!                  ...
    99+
    2023-06-14
  • 前端面试中字节的笔试题和算法题示例分析
    这篇文章将为大家详细讲解有关字节的笔试题和算法题示例分析,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。题目给定一个包含 m x n 个元素的矩阵(m 行, ...
    99+
    2024-04-02
  • Redis面试题的示例分析
    这篇文章给大家分享的是有关Redis面试题的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。应用场景缓存共享Session消息队列系统分布式锁相关推荐:Redis视频教程单...
    99+
    2024-04-02
  • Redis的面试题及答案有哪些
    这篇文章主要讲解了“Redis的面试题及答案有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Redis的面试题及答案有哪些”吧!说说Redis基本数据类型有哪些吧字符串:redis没有直...
    99+
    2023-06-27
  • Node.js面试问题的示例分析
    这篇文章主要介绍了Node.js面试问题的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。什么是error-first的回调方式Err...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作