关于PHP中key和current,next的联合运用

原创 2012年03月26日 19:10:33

来自http://bbs.php100.com/read-htm-tid-294974.html的一个小问题:

$arrq = array();
$arrq['tuc'] = array('sss'=>'ewq','shu'=>'sjkah','saa'=>'dwjhaz');
$arrq['tucs'] = array('ssss'=>'ewsq','sQhu'=>dwjhaz','sa12a'=>'dwjQhaz');
$arrq['tuca'] = array('sssd'=>'ewqq','shu2'=>'sjkah','saSa'=>'dwjhhaz');
如何在不破坏数组结构的情况下去除$arrq数组中的重复的值?
求详细思路/代码,谢谢!


思路为:先将第一个二维数组中的元素用array_unique函数输出。
输出第二个二维数组中的元素时,自己先用array_unique处理,再去掉在第一个二维数组中已经存在的元素。
输出第三个时,自己先用array_unique处理,再去掉在第一个和第二个二维数组合集中已经存在的元素。

以此类推。

总之,自己先要array_unqiue去重,再去掉自身中在前面所在数组元素合集中存在的元素。


以下为代码:

<?php
$arrq = array();
$arrq['tuc'] = array('sss'=>'ewq','shu'=>'sjkah','saa'=>'dwjhaz');
$arrq['tucs'] = array('ssss'=>'ewsq','sQhu'=>'dwjhaz','sa12a'=>'dwjQhaz');
$arrq['tuca'] = array('sssd'=>'ewqq','shu2'=>'sjkah','saSa'=>'dwjhhaz');
$last=array();                //设置一个空的用来比较的数组
while($arr=current($arrq)) {
	//echo key($arrq);
	$tmp=array_unique($arr);  //先清除每个一维数组自身相同的值
	if(count($last)==0) {
		$last=array_merge($last,$arr);    //将已经去重的前面的数组合并
	}
	else {                    // 对其余一维数组进行输出
		//echo key($arrq);
		foreach($arr as $ke=>$va) {
			if(in_array($arr[$ke], $last))   //如果已经存在的元素
			unset($arrq[key($arrq)][$ke]);                //删除,此处取得数组元素的KEY值是关键
		}
		$last=array_merge($last,$arr);                    //将$last变为前面数组的合集,用来进行下次比较
	}
	next($arrq);                               //指针向后移,这样才能用key函数取得不同的$arrq的下标
}


//以下输出处理后的数组
foreach($arrq as $arr) {
	foreach($arr as $val) {
		echo $val." ";
	}
	echo "<br>";
}
?>

运行结果为:


騰讯活动网↓经理专线

腾讯公司总部专线∶【400-067+9599】(客户部王经理接听) 腾讯公司总部二线∶【400-067+9599】(7×24小时为您服务) 腾讯公司总部专线∶【400-067+9599】(7×24...

php 函数 key()、current()

$people = array("2"=>"Bill", "Steve", "Mark", "David");echo key($people) . ""; echo current($people)...

current() ,next(),key()等数组指针函数

current() ,next(),key()等数组指针函数

使用next-key locks 用于搜索和索引扫描,可以防止幻读

Next-Key Locks A next-key lock is a combination of a record lock on the index record and a gap lock...

间隙锁(Next-Key锁)

20.3.5 间隙锁(Next-Key锁) 2008-03-27 22:22 唐汉明 翟振兴 兰丽华 关宝军 申宝柱 人民邮电出版社 字号:T | T 综合评级: 想读(11)  在读(4)  已...

mysql锁(九)innodb下的记录锁,间隙锁,next-key锁

你需要知道的 之前我们介绍了排他锁,其实innodb下的记录锁(也叫行锁),间隙锁,next-key锁统统属于排他锁。 行锁 记录锁其实很好理解,对表中的记录加锁,叫做记录锁,简称行锁。 生活中的间隙...

MySQL InnoDB中的行锁 Next-Key Lock消除幻读

InnoDB中有三种行锁技术: Record Lock:单个行记录上的锁,我们通常讲的行锁,它的实质是通过对索引的加锁实现;只有通过索引条件检索数据,InnoDB才使用行级锁,否则,InnoDB将使用...

理解innodb的锁(record,gap,Next-Key lock)

Record lock 单条索引记录上加锁,record lock锁住的永远是索引,而非记录本身,即使该表上没有任何索引,那么innodb会在后台创建一个隐藏的聚集主键索引,那么锁住的就是这个隐藏的聚...

mysql innodb next-key locking

首先看一下官方文档中关于MYSQL中各种记录级锁的解释 InnoDB has several types of record-level locks:     Record loc...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:关于PHP中key和current,next的联合运用
举报原因:
原因补充:

(最多只允许输入30个字)