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(…………) ;// 假设有数组包含一万个元素,里面有重复的元素 ...
随机推荐
- 使用View填充ViewPager
ViewPager在app开发中十分常见.今天以一个例子详细解读下ViewPager的基础知识. 一.什么是ViewPager 可以这样理解,ViewPager就相当于一个容器,它的里面可以装view ...
- SOJ4478 Easy Problem II(模拟、栈)
Time Limit: 3000 MS Memory Limit: 131072 K Description 在数据结构中 我们学习过 栈 这种数据结构 通过栈 我们可以将1,2,3,...,n转化成 ...
- Codeforces Round #535 (Div. 3) E2. Array and Segments (Hard version) 【区间更新 线段树】
传送门:http://codeforces.com/contest/1108/problem/E2 E2. Array and Segments (Hard version) time limit p ...
- HDU 1281 棋盘游戏 【二分图最大匹配】
传送门:http://acm.hdu.edu.cn/showproblem.php?pid=1281 题意概括: 有N*M大的棋盘,要在里面放尽量多的“车”,求最多能放的车的个数,和为了放最多的车有多 ...
- HDU 1019 (多个数的最小公倍数)
传送门:http://acm.hdu.edu.cn/showproblem.php?pid=1019 Least Common Multiple Time Limit: 2000/1000 MS (J ...
- 高并发Web服务的演变——节约系统内存和CPU
节约系统内存和CPU http://www.csdn.net/article/2015-02-12/2823952 Web系统大规模并发——电商秒杀与抢购 http://www.csdn.net/ar ...
- LeetCode21.合并两个有序链表 JavaScript
将两个有序链表合并为一个新的有序链表并返回.新链表是通过拼接给定的两个链表的所有节点组成的. 示例: 输入:1->2->4, 1->3->4 输出:1->1->2- ...
- Python 学习笔记(九)Python元组和字典(二)
什么是字典 字典是另一种可变容器模型,且可存储任意类型对象. 字典的每个键值 key=>value 对用冒号 : 分割,每个键值对之间用逗号 , 分割,整个字典包括在花括号 {} 中 键必须是唯 ...
- Asset Catalogs
原文见这里. Asset Catalogs用于简化管理程序内用到的图片.每个asset catalog可以包含image set, App Icon, Launch Image和OS X Icon(如 ...
- 哈希查找解决地址冲突的两种最常见方法(线性探测再散列,链地址法)C++实现
#include<iostream>#include<iomanip>using namespace std; typedef struct Node{ int data; s ...