PHP数组中插入元素
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数组中插入元素的更多相关文章
- js向一个数组中插入元素的几个方法-性能比较
向一个数组中插入元素是平时很常见的一件事情.你可以使用push在数组尾部插入元素,可以用unshift在数组头部插入元素,也可以用splice在数组中间插入元素. 但是这些已知的方法,并不意味着没有更 ...
- [jstips]向数组中插入一个元素
向现有数组中插入一个元素是经常会见到的一个需求.你可以: 使用push将元素插入到数组的尾部: 使用unshift将元素插入到数组的头部: 使用splice将元素插入到数组的中间: 上面那些方法都是常 ...
- js有序数组中插入一个元素,并有序的输出
题目:比较传入函数的参数,将参数组成数组,从小到大排序,返回新的数组. 如: insert();console.log(arr); //[] insert(-1,-2); console.log(ar ...
- 数组中的元素 增加push用法 unshift() 方法 和减少pop() 方法 shift() 和其他位置增删 splice() 方法 join() 方法 reverse() 方法 sort() 方法
push用法 push 英 [pʊʃ] 美 [pʊʃ] vt. 推,推动; vt. 按; 推动,增加; 对…施加压力,逼迫; 说服; n. 推,决心; 大规模攻势; 矢志的追求 定义和用法 push( ...
- LeetCode数组移除数组中目标元素等题目
一种自己解题,一种高赞解题 /** * 移除数组中目标元素,返回新数组长度 * @param nums * @param val * @return */ public int removeEleme ...
- 【Java实现】剑指offer53.1——在排序数组中查找数字(LeetCode34:在排序数组中查找元素的起始位置)
序数组中查找元素的起始位置):思路分享 <剑指offer>题目和LeetCode主站本质是一样的,想要找到target数目,也需要找到左右边界 题目解析: 在一个排序数组中,找到targe ...
- 【LeetCode】34. 在排序数组中查找元素的第一个和最后一个位置
34. 在排序数组中查找元素的第一个和最后一个位置 知识点:数组,二分查找: 题目描述 给定一个按照升序排列的整数数组 nums,和一个目标值 target.找出给定目标值在数组中的开始位置和结束位置 ...
- 面试题-->写一个函数,返回一个数组中所有元素被第一个元素除的结果
package com.rui.test; import java.util.Random; /** * @author poseidon * @version 1.0 * @date:2015年10 ...
- php 去除数组中重复元素
去除数组中重复元素, 找了下可以一下两个函数 php array_flip()与array_uniqure() $arr = array(…………) ;// 假设有数组包含一万个元素,里面有重复的元素 ...
随机推荐
- AtomicInteger线程安全的计数器
在多线程环境下计数的时候,++i和i++是不安全的,故而需要加锁机制,也可以使用volatile关键字进行修饰,但是更简单有效的方式是使用Atomic类
- What Are Threads?
https://developer.apple.com/library/content/documentation/Cocoa/Conceptual/Multithreading/AboutThrea ...
- 【[SCOI2010]股票交易】
感谢dzm,尽管接受了\(The \text{ }\text{ }king\text{ } \text{ }of\text{ } \text{ }SD\)的指点但我还是不会 至少方程还是比较好推的 状 ...
- java线程安全单例
public class MySingleton { // 使用volatile关键字保其可见性 volatile private static MySingleton instance = null ...
- Swift_函数
Swift_函数 点击查看源码 定义和调用函数 //定义和调用函数 func testDefiningAndCallingFunctions() { func sayHello(_ personNam ...
- 算法基础-dfs
最近在学dfs(深度优先搜索),dfs与树的遍历差不多,就是先从一个点开始一直搜索,直到走不动为止.现在推荐一个简单的dfs题, 百炼的2815, ########################## ...
- POJ 3528--Ultimate Weapon(三维凸包)
Ultimate Weapon Time Limit: 2000MS Memory Limit: 131072K Total Submissions: 2430 Accepted: 1173 ...
- 【2013 ICPC亚洲区域赛成都站 F】Fibonacci Tree(最小生成树+思维)
Problem Description Coach Pang is interested in Fibonacci numbers while Uncle Yang wants him to do s ...
- Xdebug 备注
安装步骤: 查看自己的环境是否已安装 Xdebug ,查看方法:使用phpinfo(),搜索 Xdebug 如果没有 如图: 如果没有:下一步确定你的PHP版本信息: Xdebug下载地址 https ...
- Jquery中菜单的展开和折叠
jquery内容 <script> $(function () { $("dl dt").click(function () { $(this).siblings(). ...