八个PHP数组面试题目_第1页
八个PHP数组面试题目_第2页
八个PHP数组面试题目_第3页
八个PHP数组面试题目_第4页
八个PHP数组面试题目_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、八个PHP数组面试题目 八个PHP数组而试题目 1. 写函数创建长度为10的数组,数组中的元素为递增的奇数, 首项为1. 代码如下: functionarrsort($first, $length) $arr=array(); for($i=$first;$i11=32=53=74=95=116=137=1 58=179=19) 2. 创建长度为10的数组,数组中的数为递增的等比数,比值为 3,首项为1. 代码如下: /$num为比值 functionarrsort($first, $length, $num) $arr=array(); for($i=$first;$i11=32=93=27

2、4=815=2436=7297 =21878=65619=19683) 3. 求数组中最大数的下标. 代码如下: functionmaxkey($arr) $maxval=max($arr); foreach(SarrasSkey=val) 辻($maxval=$val) Smaxkey=Skey; returnSmaxkey; $arr=array (0, -1, -2, 5, b二15, 3); echomaxkey($arr); 输出: 代码如下: b 4. 创建一个长度为10的数组,数组中的元素满足斐波拉契数列 的规律. (斐波那契数列,又称黄金分割数列,指的是这样一个数列:1、 1、

3、2、3、5、8、13、21、在数学上,斐波纳契数列以如下被以 递归的.方法定义:F0=0, Fl=l, Fn=F(n-l)+F(n-2) (n=2, nN*). 特别指出:第0项是0,第1项是第一个1。) 代码如下: functionarrFibo($len) $arr0=0; $arrl=l; for($i=2;$i0 1 =1 2 =1 3 =2 4 二3 5 =5 6 =8 7 =13 8 =21 二34 ) 5. 计算数组中最大数和最小数的差. 两种方法: max/min 输出: 代码如下: 102 sort把元素按从小到大排序/rsort吧元素按从大到小排序 代码如下: functi

4、onarrsub($arr) sort($arr); $min=$arr0; rsort($arr); $max=$arr0; $sub=$max-$min; returnSsub; $arr=array (-1, -2, 100); echoarrsub($arr); 输出: 102 6. 写一个方法,将一个长度超过10的数组最后5项直接截取, 不改变顺序变为前5项,如1, 2, 3, 4, 5, 6, 7, 8, 9, 10变为 6, 7, 8, 9, 10, 1,2, 3, 4,5. 思路:先把数组截取相应的长度(array_slice),再把2段数组 拼接(array_merge) 代

5、码如下: functionarrsort(Sarr) $num二count($arr); 辻($num10) /array_sl ice (Sarr,起始位置,截取长度,保留索引(默认为 false) $arr_f irstpart=array_slice($arr, 0, num-5, true); $arr_lastpart二array_slice($arr, ($num-5), 5,true); else echo数组不超过10个元素,请重新输入; exit (); /拼接 Sarr_new=array_merge($arr_lastpart,$arr_firstpart); retur

6、nSarr_new; $arr二array ( echo f print_r ($arr); echo二二=二拼接后二二=; print_r(arrsort($8ir); echo 输出: 代码如下: Array ( a 二1 0二2 1 =3 2 =8 二9 4 =6 b 二5 5 二-1 c =8 6 二0 二7 ) 二二二二二拼接后二二二二 代码如下: Array ( b 二5 0二-1 c =8 1 =0 二7 a=l 3 =2 4 二3 5 二8 6 二9 7 二6 ) 当数组不满足长度为10时: 代码如下: Sarr=array (,za,/=l, 2, 3); 输出: 代码如下:

7、 Array ( a二1 0二 2 二3 ) 二二二二二拼接后= 数组不超过10个元素,请重新输入 7. 将两个数组连接成一个新数组. 方法使用array_merge ()函数 代码如下: array_merge($arrl, $arr2); 方法使用array_merge_recursive()函数递归追加数组 (array_merge_recursive ()函数与 array_merge ()函数一样,将 一个或多个数组的元素的合并起来,一个数组中的值附加在前一个 数组的后面。并返回作为结果的数组。 但是,与array_merge ()不同的是,当有重复的键名时,值不会 被覆盖,而是将多

8、个相同键名的值递归组成一个数组。) 代码如下: $arr=array (,a/,=l, b=2, 3); $arr2=array (,a/z=Dee, 3, 5); $arr3=array_merge($arr, $arr2); Sarr4=array_merge_recursive($arr, $arr2); echo print_:r (Sarr3); echo 二二二二二; print_r (Sarr4); echo . f 输出: 代码如下: Array ( a =Dee b 二 2 0二3 1 =3 二5 ) 代码如下: Array ( a =Array ( 0=1 l=Dee )

9、b =2 0=3 1 二3 2 =5 ) 第一个输出的数组中索引为冷的值1被索引被第二个数组中索 引为律的值Dee覆盖了。 方法 代码如下: functionarrsort ($a:rrl, $arr2) $arr_new=$arrl; foreach ($arr2as$key=$val) Sarr_new=$val; returnSarr_new; $arrl=array (,a,/=l, b=2, 3); Sarr2=array (,a/=Dee, c=3, 5); echo f print_r (arrsort($arrl,Sarr2); echo r 输出: 代码如下: Array ( a =l b 二 2 0二3 1 =Dee 2 =3 3 =5 ) 如果是索引数组而且有重复的索引,则第二个数组中的这个重复 的索引会被修改成新的索引。 8. 数组逆序(不能使用rsort函数,不能生成新数组) 使用array_reverse()函数会创建新的数组,所以不能使用。 代码如下: $arr二array

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论