剑指offer试题(PHP篇三)
21.栈的压入、弹出序列
题目描述
<?php function IsPopOrder($pushV, $popV)
{
// write code here
$stack = new SplStack;
$count = count($pushV);
for($i=0,$j=0;$i<$count;$i++){
$stack->push($pushV[$i]);
while(!$stack->isEmpty()&&$stack->top()==$popV[$j]&&$j<$count){
$stack->pop();
$j++;
}
}
return $stack->isEmpty();
}
运行时间:9ms 占用内存:3840k
思路:
借用一个辅助的栈,遍历压栈顺序,先讲第一个放入栈中,这里是1,然后判断栈顶元素是不是出栈顺序的第一个元素,这里是4,很显然1≠4,所以我们继续压栈,直到相等以后开始出栈,出栈一个元素,则将出栈顺序向后移动一位,直到不相等,这样循环等压栈顺序遍历完成,如果辅助栈还不为空,说明弹出序列不是该栈的弹出顺序。
22.从上往下打印二叉树
题目描述
<?php
/*class TreeNode{
var $val;
var $left = NULL;
var $right = NULL;
function __construct($val){
$this->val = $val;
}
}*/
function PrintFromTopToBottom($root)
{
// write code here
$queue = array();
$list = array();
array_push($queue,$root);
while(count($queue)>0){
array_push($list,$queue[0]->val);
$tmp = array_splice($queue,0,1);
if($tmp[0]->left != null){
array_push($queue,$tmp[0]->left);
}
if($tmp[0]->right != null){
array_push($queue,$tmp[0]->right);
}
}
return $list;
}
题目描述
<?php function VerifySquenceOfBST($sequence)
{
// write code here
$size = count($sequence);
if($size == 0){
return false;
}
$i = 0;
while($size--){
while($sequence[$i++]<$sequence[$size]);
while($sequence[$i++]>$sequence[$size]);
if($i<$size){
return false;
}
$i = 0;
}
return true;
}
运行时间:12ms 占用内存:2572k
思路:
只要想清楚左节点比根节点小,右节点比根节点大就很容易解出,首先将数组的大小赋给$size,对$size进行while循环,这里有一个很重要的变量$i,两个while循环一个判断左节点和根节点的大小关系,若左小于根,则$i++,继续循环,之后判断右是否大于根,若大于,$i++,然后判断变量i和变量size的大小关系,如果i小于size,则说明没有循环完,即这不是一个二叉搜索树,返回false,反之则继续size--循环,当然要将i重新赋值0,直到size为0时,循环结束,返回true。
24.二叉树中和为某一值的路径
题目描述
<?php
/*class TreeNode{
var $val;
var $left = NULL;
var $right = NULL;
function __construct($val){
$this->val = $val;
}
}*/
function FindPath($root, $expectNumber)
{
// write code here
$arr = $tmp = [];
if(!$root){
return $arr;
}
find($root,$expectNumber,$arr,$tmp);
return $arr;
}
function find($root,$sum,&$arr,$tmp){
if($root!= null){
$sum-=$root->val;
$tmp[] = $root->val;
if($sum>0){
find($root->left,$sum,$arr,$tmp);
find($root->right,$sum,$arr,$tmp);
}elseif($sum==0 && $root->left == null && $root->right == null){
$arr[] = $tmp;
}
}
}
运行时间:12ms 占用内存:2316k
思路:
一个简单的递归函数,通过把每次减去的根节点的值存入临时数组tmp中,最后进行判断是否减到了零,并且是叶子节点,若是,再将tmp数组中的数转移到arr数组中,输出。
25.复杂链表的复制
题目描述
<?php
/*class RandomListNode{
var $label;
var $next = NULL;
var $random = NULL;
function __construct($x){
$this->label = $x;
}
}*/
$r = [];
function MyClone($pHead)
{
// write code here
global $r;
if($pHead == NULL){
return NULL;
}
$PnewHead=new RandomListNode($pHead->label);
$PnewHead->next=MyClone($pHead->next);
$PnewHead->random=$pHead->random;
return $PnewHead;
}
运行时间:16ms 占用内存:2432k
思路:
复杂链表是一种不太常见的数据结构,而且复制这种链表的过程也较为复杂,这里有一个小坑,就是找当前节点的下一个节点时用的是递归,但找他的random节点时只需要复制$pHead->random就行了,用不到递归。
26.二叉搜索树与双向链表
题目描述
输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。
时间限制:1秒 空间限制:32768K
<?php
/*class TreeNode{
var $val;
var $left = NULL;
var $right = NULL;
function __construct($val){
$this->val = $val;
}
}*/
$nodes = array();
function Convert($pRootOfTree)
{
// write code here
GLOBAL $nodes;
$nodes = array();
inOrder($pRootOfTree);
for($i=0;$i<count($nodes)-1;$i++){
$nodes[$i]->right = $nodes[$i+1];
$nodes[$i+1]->left = $nodes[$i];
}
return $nodes[0];
} function inOrder($root){
GLOBAL $nodes;
if($root == null){
return;
}else{
inOrder($root->left);
$nodes[] = $root;
inOrder($root->right);
}
}
运行时间:9ms 占用内存:4060k
思路:
这种方法的思路就是首先递归将搜索二叉树中的节点按照中序遍历的顺序存入到nodes中,然后对nodes进行遍历,使他相邻两个值互为左右子节点(双向链表)。
27.字符串的排列
题目描述
<?php function Permutation($str)
{
$ans = array();
permutation2(0,$str,$ans);
$ans = array_unique($ans);
sort($ans);
return $ans;
} function permutation2($step,&$str,&$ans){
if($step==strlen($str)-1){
$ans[] = $str;
}
for($i=$step;$i<strlen($str);$i++){
$tmp = $str[$step]; $str[$step] = $str[$i]; $str[$i] = $tmp;
permutation2($step+1,$str,$ans);
$tmp = $str[$step]; $str[$step] = $str[$i]; $str[$i] = $tmp;
}
}
运行时间:12ms 占用内存:3936k
思路:
利用递归,通过对step位数的控制,每次交换两个字母的位置,将所有可能的情况罗列出来,存入ans数组中,最后将其去重,排序,即可得到最终结果。
28.数组中出现次数超过一半的数字
题目描述
时间限制:1秒 空间限制:32768K
<?php function MoreThanHalfNum_Solution($numbers)
{
// write code here
if(count($numbers) <= 0)
return 0;
$list = array_count_values($numbers);
$max = max($list);
if(2*$max > count($numbers))
return array_search($max, $list);
else
return 0;
}
运行时间:12ms 占用内存:2432k
思想:
博主在这里偷懒了,使用了php的函数array_count_values,将数组中所有值当做下标,出现的次数当做值放入一个新的数组中,瞬间发现这个题简单了好多,找到数组中最大值的那一项,判断最大值的二倍与原数组长度谁大,来返回结果。
29.最小的K个数
题目描述
<?php function GetLeastNumbers_Solution($input, $k)
{
// write code here
sort($input);
$res = [];
if(count($input)>0 && count($input)>=$k){
$res = array_slice($input,0,$k);
return $res;
}else{
return $res;
} }
运行时间:17ms 占用内存:3940k
思路:
先排序,然后使用array_slice,取出数组中前k个值,放入res数组中,返回即可,注意判断输入的数组和k是否符合范围,若不符合就返回空数组。
30.连续子数组的最大和
题目描述
<?php function FindGreatestSumOfSubArray($array)
{
// write code here
$count = count($array);
$max = $array[0];
for($i=0;$i<$count;$i++){
$sum = 0;
for($j=$i;$j<$count;$j++){
$sum+=$array[$j];
if($sum>$max){
$max = $sum;
}
}
}
return $max;
}
运行时间:10ms 占用内存:2432k
思路:
双层循环遍历,找出一个和最大的值,并返回这个和。
注:以上均为个人理解,如有错误,请提出,必改正。
剑指offer试题(PHP篇三)的更多相关文章
- 剑指offer试题(PHP篇一)
1.二维数组中的查找 题目描述 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. ...
- 剑指offer试题(PHP篇二)
6.旋转数组的最小数字 题目描述 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素. 例如数组{3,4,5,1,2}为{1 ...
- 剑指offer试题(PHP篇四)
16.合并两个排序的链表 题目描述 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 时间限制:1秒 空间限制:32768K <?php /*c ...
- 【Warrior刷题笔记】剑指offer 6 24 35. 三道题,让你学会链表递归迭代辅助栈
题目一 从尾到头打印链表 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/cong-wei-dao-tou-da-yin-lian-biao-l ...
- 剑指offer 面试65题
题目65题:不用加减乘除做加法. 解法一:Python特性 # -*- coding:utf-8 -*- class Solution: def Add(self, num1, num2): # wr ...
- 剑指Offer——滴滴笔试题+知识点总结
剑指Offer--滴滴笔试题+知识点总结 情景回顾 时间:2016.9.18 15:00-17:00 地点:山东省网络环境智能计算技术重点实验室 事件:滴滴笔试 总体来说,滴滴笔试内容体量不算多, ...
- 剑指offer之面试题2:实现Singleton模式
来源:剑指offer 这篇主要记录<剑指offer>书籍中的面试题2:实现Singleton模式 使用语言:C# 代码环境:VS2017 总共有5中解法,从前往后依次优化. 结构如下: 前 ...
- 剑指Offer面试题:1.实现Singleton模式
说来惭愧,自己在毕业之前就该好好看看<剑指Offer>这本书的,但是各种原因就是没看,也因此错过了很多机会,后悔莫及.但是后悔是没用的,现在趁还有余力,把这本书好好看一遍,并通过C#通通实 ...
- 《剑指offer》面试题12:打印1到最大的n位数
面试题12:打印1到最大的n位数 剑指offer题目12,题目如下 输入数字n,按顺序打印出1到最大的n位十进制数,比如输入3,则打印出1,2,3一直到最大的三位数999 方法一 和面试题11< ...
随机推荐
- oc消息转发:forwardInvocation、签名、参量个数、SEL 相关测试
结论1.签名的参量类型伪造不正确会导致崩溃. 结论二.签名个数不对可能会导致参量丢失. 结论三:在签名配置正确的情况下,系统会将函数调用的所有信息打包到NSInvocation准备转发: - (voi ...
- 有料面试题之--Object里面的方法
阿里的面试题里面有个题很奇妙:你知道Object类里面有哪些方法吗? 绝大部分猿类都知道 有hashcode .equals .clone.toString 只有部分人会回答有 wait和notify ...
- POJ3977 Subset
嘟嘟嘟 这个数据范围显然是折半搜索. 把序列分成两半,枚举前一半的子集,存下来.然后再枚举后一半的子集,二分查找. 细节: 1.最优解可能只在一半的子集里,所以枚举的时候也要更新答案. 2.对于当前结 ...
- yii 执行流程
应用执行流程: 浏览器向服务器发送 Http Request | 控制器(protected/controllers) | |---> Action | 创建模型 (Model) | 检查$_P ...
- Zookeeper框架Curator使用
本文参考自https://blog.csdn.net/wo541075754/article/details/69138878?utm_source=gold_browser_extension ht ...
- 使用阿里云的maven仓库
在maven的settings.xml文件里的mirrors节点,添加如下子节点: <mirror> <id>nexus-aliyun</id> <mirro ...
- Python文件和流
#coding = utf-8 from pprint import pprint import fileinput #read(n) f = open(r'E:\test_dir\somefile. ...
- selenium + python自动化测试unittest框架学习(六)分页
接触的项目分页的形式是以下形式: 想要获取总页数后,遍历执行翻页的功能,但由于分页是以javascript方法实现的,每次点击确定按钮后,页面就回刷新,webelement元素过期无法遍历下一个进行翻 ...
- UNIX网络编程 卷2 源代码使用
1. 下载源码,W. Richard Stevens的主页:http://www.kohala.com/start/ wget http://www.kohala.com/start/unpv22e/ ...
- Nginx-------Nginx的安装和多域名配置
Nginx安装 centos6.x yum默认没有nginx的软件包 安装方式: 到nginx下载页面http://nginx.org/en/linux_packages.html#stable,复制 ...