11.二进制中1的个数php
<?php function NumberOf1($n) { // write code here $count = 0; if($n<0){ $n=$n & 0X7FFFFFFF; $count++; } while($n){ $n=($n-1)&$n; $count++; } return $count; }
运行时间:11ms 占用内存:2316knode
感悟:算法
说实话,这类题是个人弱项,想了大半天,无从下手,后来仍是在上网搜了些资料后,才勉强解出。首先判断n是否是负数,当n为负数的时候,直接用后面的循环会致使死循环,由于负数向左移位的话最高位补1! 所以须要一点点特殊操做,能够将最高位的符号位1变成0,也就是n & 0x7FFFFFFF,这样就把负数转化成正数了,惟一差异就是最高位由1变成0,由于少了一个1,因此count加1。以后再按照while循环里处理正数的方法来操做就能够完美解决。<?php function Power($base, $exponent) { // write code here return pow($base,$exponent); }
运行时间:15ms 占用内存:2432k数组
感悟:数据结构
这题用php作和做弊同样。。。呃,固然,身为一个正直的人,仍是要把用算法思路写的解贴出来。函数
<?php function Power($base, $exponent) { if($exponent >= 0){ $res = 1; while($exponent >= 1){ $res = $res * $base; $exponent--; } return $res; } if($exponent < 0){ $exponent2 = abs($exponent); $res = 1; while($exponent2 >=1){ $res = $res *$base; $exponent2--; } return 1/$res; } }
其实也不是很难啦= =。this
13.调整数组顺序使奇数位于偶数前面spa
<?php function reOrderArray($array) { // write code here $tmp1 = []; $tmp2 = []; for($i=0;$i<count($array);$i++){ if($array[$i]%2){ $tmp1[] = $array[$i]; }else{ $tmp2[] = $array[$i]; } } for($j=0;$j<count($tmp2);$j++){ $tmp1[]=$tmp2[$j]; } return $tmp1; }
运行时间:10ms 占用内存:2432kcode
感悟:blog
这道题不算难,算法思路:建立两个临时数组,经过对原数组的每一个值进行判断,奇偶分别存入两个临时数组中,再将偶数组放入奇数组以后便可。
14.链表中倒数第k个结点
<?php /*class ListNode{ var $val; var $next = NULL; function __construct($x){ $this->val = $x; } }*/ function FindKthToTail($head, $k) { // write code here $tmp=$head; $len=0; while($head!=null){ $len++; $head=$head->next; } if($k>$len){ return null; } for($i=0;$i<$len-$k;$i++){ $tmp=$tmp->next; } return $tmp; }
运行时间:25ms 占用内存:2316k
感悟:
这道题的思路很是清晰,即首先求出链表长度,判断k结点是否超出链表长度,若符合要求,则经过循环找到第k个结点并返回。
15.反转链表
<?php /*class ListNode{ var $val; var $next = NULL; function __construct($x){ $this->val = $x; } }*/ function ReverseList($pHead) { // write code here if($pHead==null){ return null; } $pre=null; while($pHead != null){ $tmp = $pHead->next; $pHead->next = $pre; $pre = $pHead; $pHead = $tmp; } return $pre; }
运行时间:9ms 占用内存:3724k
感悟:
这道链表题自我感受仍是有点点绕的(我的大脑不是很发达。。。),思路,简单来讲就是不断的取出原链表的头,而后存入pre的尾部,这样作的结果就是将整个链表反转。
16.合并两个排序的链表
<?php /*class ListNode{ var $val; var $next = NULL; function __construct($x){ $this->val = $x; } }*/ function Merge($pHead1, $pHead2) { // write code here $pHead = new ListNode(null); if($pHead1 == null){ return $pHead2; }elseif($pHead2 == null){ return $pHead1; }else{ if($pHead1->val<$pHead2->val){ $pHead=$pHead1; $pHead->next=Merge($pHead1->next,$pHead2); }else{ $pHead=$pHead2; $pHead->next=Merge($pHead1,$pHead2->next); } } return $pHead; }
运行时间:13ms 占用内存:2560k
感悟:
思路很简单,按顺序合并两个有序的链表,只要针对 每一个链表的第一个值进行比较,再递归调用Merge函数便可。
17.树的子结构
<?php /*class TreeNode{ var $val; var $left = NULL; var $right = NULL; function __construct($val){ $this->val = $val; } }*/ function HasSubtree($pRoot1, $pRoot2) { // write code here if($pRoot1 == null || $pRoot2 == null){ return false; } return isSubtree($pRoot1,$pRoot2) || isSubtree($pRoot1->left,$pRoot2) || isSubtree($pRoot1->right,$pRoot2); } function isSubtree($pRoot1,$pRoot2){ if($pRoot2 == null){ return true; } if($pRoot2 == null){ return false; } return $pRoot1->val == $pRoot2->val && isSubtree($pRoot1->left,$pRoot2->left) && isSubtree($pRoot1->right,$pRoot2->right); }
运行时间:11ms 占用内存:2432k
感悟:
首先判断两个链表是否为空,若空则返false,若不空,则递归调用isSubtree函数,这里要注意调用时要将链表1自己,其左子树,其右子树分别和链表2进行比较,若链表1的比较不成立,再进行其左子树和右子树的调用比较,若链表1自己就成立,则后面的两次调用就没有必要。再来讲isSubtree函数,题目要求判断b是否是a的子结构,因此分别判断传入参数的两个链表是否为空,若1空,则返回false,若2空,则确定是子结构,返回true,最后用与运算递归调用isSubtree函数进行子树的比较。
18.二叉树的镜像
二叉树的镜像定义:源二叉树 8 / \ 6 10 / \ / \ 5 7 9 11 镜像二叉树 8 / \ 10 6 / \ / \ 11 9 7 5
时间限制:1秒 空间限制:32768K
<?php /*class TreeNode{ var $val; var $left = NULL; var $right = NULL; function __construct($val){ $this->val = $val; } }*/ function Mirror(&$root) { // write code here if($root == null || ($root->left == null && $root->right == null)){ return; } $tmp = $root->left; $root->left = $root->right; $root->right = $tmp; if($root->left){ Mirror($root->left); } if($root->right){ Mirror($root->right); } return $root; }
运行时间:12ms 占用内存:2428k
感悟:
首先判断该二叉树是否为空树或者是否只有一个节点,若不是,则进行左右子节点的交换,最后将左右节点分别判断,再递归调用原函数Mirror()。
19.顺时针打印矩阵
function printMatrix($matrix) { // write code here $output = []; $left = 0; $right = count($matrix[0]); $top = 0; $buttom = count($matrix); if ($right == 0 && $buttom == 0) { return $output; } $right--; $buttom--; while($left <= $right && $top <= $buttom) { for ($i = $left; $i <= $right; $i++) $output[] = $matrix[$top][$i]; if ($top + 1 > $buttom) break; for ($i = $top + 1; $i <= $buttom; $i++) $output[] = $matrix[$i][$right]; if ($right - 1 < $left) break; for ($i = $right - 1; $i >= $left; $i--) $output[] = $matrix[$buttom][$i]; if ($buttom - 1 <= $top) break; for ($i = $buttom -1 ; $i > $top; $i--) $output[] = $matrix[$i][$left]; $left++; $right--; $top++; $buttom--; } return $output; }
运行时间:22ms 占用内存:7808k
感悟:
顺时针打印矩阵中的数值,把握好变量的取值,先判断给出的数组是否为空,以后根据top,buttom,left,right四个变量进行左到右,上到下,右到左,下到上的遍历赋值,进行一遍循环后,矩形缩小一圈,左加右减,上加下减,继续遍历,直到left大于等于right且top大于等于buttom,循环结束,输出output数组。
20.包含min函数的栈
<?php global $mystack; $mystack = []; function mypush($node) { // write code here global $mystack; array_push($mystack,$node); } function mypop() { // write code here global $mystack; array_pop($mystack); } function mytop() { // write code here global $mystack; if(count($mystack) == 0){ return null; } return $mystack[count($mystack)-1]; } function mymin() { // write code here global $mystack; $min = $mystack[0]; for($i=0;$i<count($mystack);$i++){ if($mystack[$i]<$min){ $min = $mystack[$i]; } } return $min; }
运行时间:11ms 占用内存:2432k
感悟:
考察栈的操做,注意定义global变量,进栈出栈,返回栈顶元素,求栈中最小元素,按照通常思路求解便可。
注:以上均为我的理解,若有错误,请提出,必改正。