1. array_unshift()数组头插入新元素

$fruits = array('apple','pear','banana','orange');
array_unshift($fruits, 'cherry');
pr($fruits); function pr($str){
echo "<pre>";
print_r($str);
echo "</pre>";
}

输出:

Array
(
[0] => cherry
[1] => apple
[2] => pear
[3] => banana
[4] => orange
)

可向array_unshift传入多个元素

$fruits = array('apple','pear','banana','orange');
array_unshift($fruits, 'cherry','pie');
pr($fruits);

输出:

Array
(
[0] => cherry
[1] => pie
[2] => apple
[3] => pear
[4] => banana
[5] => orange
)

2. 与之类似的函数array_push,向数组末尾插入一个或多个元素。

3. array_splice()任意位置插入新元素(不考虑键名)

$fruits = array('apple','pear','banana','orange');
//第三个参数固定为0,第二个参数为插入的索引位置,最后一个参数是插入的元素,如果插入多个,写成数组
array_splice($fruits,3,0,'pie');
pr($fruits);

输出:

Array
(
[0] => apple
[1] => pear
[2] => banana
[3] => pie
[4] => orange
)

//插入多个新元素,写成数组形式

$fruits = array('apple','pear','banana','orange');
$new_items = array('pie','pie2');
array_splice($fruits,3,0,$new_items);
pr($fruits);

输出:

Array
(
[0] => apple
[1] => pear
[2] => banana
[3] => pie
[4] => pie2
[5] => orange
)

4. 任意位置插入新元素(考虑数字键名的情况)

使用array_splice()有个不好的地方,不能保留数字键名。

下面有一已知数组array(7=>'apple',3=>'pear',5=>'banana',2=>'orange');

要向第二个元素pear后面插入一新元素new fruit,键名是6.

实现过程有点曲折,新数组由三部分组成。具体见代码:

$new_key = 6;
$new_value = 'new fruit';
$exist_value = 'pear';
$array = array(7=>'apple',3=>'pear',5=>'banana',2=>'orange'); $pp = insert_array($array,$exist_value,$new_key,$new_value);
pr($pp); function insert_array($array,$exist_value,$new_key,$new_value){
$search_key = array_search($exist_value,array_values($array));
if($search_key !== false){
$new_array = array();
$len = count($array);
$arr_before = array_slice($array,0,$search_key+1,TRUE);
$arr_after =$search_key == 0 ? array_slice($array,$search_key,$len,TRUE) : array_slice($array,$search_key-1,$len,TRUE);
foreach($arr_before as $k=>$v){
$new_array[$k] = $v;
}
$new_array[$new_key] = $new_value;
foreach($arr_after as $k=>$v){
$new_array[$k] = $v;
}
}else{
$new_array = $array;
$new_array[$new_key] = $new_value;
}
return $new_array;
}

PHP数组中插入元素的更多相关文章

  1. js向一个数组中插入元素的几个方法-性能比较

    向一个数组中插入元素是平时很常见的一件事情.你可以使用push在数组尾部插入元素,可以用unshift在数组头部插入元素,也可以用splice在数组中间插入元素. 但是这些已知的方法,并不意味着没有更 ...

  2. [jstips]向数组中插入一个元素

    向现有数组中插入一个元素是经常会见到的一个需求.你可以: 使用push将元素插入到数组的尾部: 使用unshift将元素插入到数组的头部: 使用splice将元素插入到数组的中间: 上面那些方法都是常 ...

  3. js有序数组中插入一个元素,并有序的输出

    题目:比较传入函数的参数,将参数组成数组,从小到大排序,返回新的数组. 如: insert();console.log(arr); //[] insert(-1,-2); console.log(ar ...

  4. 数组中的元素 增加push用法 unshift() 方法 和减少pop() 方法 shift() 和其他位置增删 splice() 方法 join() 方法 reverse() 方法 sort() 方法

    push用法 push 英 [pʊʃ] 美 [pʊʃ] vt. 推,推动; vt. 按; 推动,增加; 对…施加压力,逼迫; 说服; n. 推,决心; 大规模攻势; 矢志的追求 定义和用法 push( ...

  5. LeetCode数组移除数组中目标元素等题目

    一种自己解题,一种高赞解题 /** * 移除数组中目标元素,返回新数组长度 * @param nums * @param val * @return */ public int removeEleme ...

  6. 【Java实现】剑指offer53.1——在排序数组中查找数字(LeetCode34:在排序数组中查找元素的起始位置)

    序数组中查找元素的起始位置):思路分享 <剑指offer>题目和LeetCode主站本质是一样的,想要找到target数目,也需要找到左右边界 题目解析: 在一个排序数组中,找到targe ...

  7. 【LeetCode】34. 在排序数组中查找元素的第一个和最后一个位置

    34. 在排序数组中查找元素的第一个和最后一个位置 知识点:数组,二分查找: 题目描述 给定一个按照升序排列的整数数组 nums,和一个目标值 target.找出给定目标值在数组中的开始位置和结束位置 ...

  8. 面试题-->写一个函数,返回一个数组中所有元素被第一个元素除的结果

    package com.rui.test; import java.util.Random; /** * @author poseidon * @version 1.0 * @date:2015年10 ...

  9. php 去除数组中重复元素

    去除数组中重复元素, 找了下可以一下两个函数 php array_flip()与array_uniqure() $arr = array(…………) ;// 假设有数组包含一万个元素,里面有重复的元素 ...

随机推荐

  1. AtomicInteger线程安全的计数器

    在多线程环境下计数的时候,++i和i++是不安全的,故而需要加锁机制,也可以使用volatile关键字进行修饰,但是更简单有效的方式是使用Atomic类

  2. What Are Threads?

    https://developer.apple.com/library/content/documentation/Cocoa/Conceptual/Multithreading/AboutThrea ...

  3. 【[SCOI2010]股票交易】

    感谢dzm,尽管接受了\(The \text{ }\text{ }king\text{ } \text{ }of\text{ } \text{ }SD\)的指点但我还是不会 至少方程还是比较好推的 状 ...

  4. java线程安全单例

    public class MySingleton { // 使用volatile关键字保其可见性 volatile private static MySingleton instance = null ...

  5. Swift_函数

    Swift_函数 点击查看源码 定义和调用函数 //定义和调用函数 func testDefiningAndCallingFunctions() { func sayHello(_ personNam ...

  6. 算法基础-dfs

    最近在学dfs(深度优先搜索),dfs与树的遍历差不多,就是先从一个点开始一直搜索,直到走不动为止.现在推荐一个简单的dfs题, 百炼的2815, ########################## ...

  7. POJ 3528--Ultimate Weapon(三维凸包)

    Ultimate Weapon Time Limit: 2000MS   Memory Limit: 131072K Total Submissions: 2430   Accepted: 1173 ...

  8. 【2013 ICPC亚洲区域赛成都站 F】Fibonacci Tree(最小生成树+思维)

    Problem Description Coach Pang is interested in Fibonacci numbers while Uncle Yang wants him to do s ...

  9. Xdebug 备注

    安装步骤: 查看自己的环境是否已安装 Xdebug ,查看方法:使用phpinfo(),搜索 Xdebug 如果没有 如图: 如果没有:下一步确定你的PHP版本信息: Xdebug下载地址 https ...

  10. Jquery中菜单的展开和折叠

    jquery内容 <script> $(function () { $("dl dt").click(function () { $(this).siblings(). ...