我想从数组中删除其中有重复数字的数字。
array('4149','8397','9652','4378','3199','7999','8431','5349','7068');
至
array('8397','9652','4378','8431','5349','7068');
我试过这个东西
foreach($array as $key => $value) {
$data = str_split($value, 1);
$check = 0;
foreach($data as $row => $element) {
$check = substr_count($value, $element);
if($check != 1) {
array_diff($array, array($value));
}
}
}
您可以使用匹配的正则表达式过滤数组:
(.)
任意字符- 后面跟零个或多个字符的
.*
'1
后面再跟一次第一个字符
示例代码:
$array = array('4149','8397','9652','4378','3199','7999','8431','5349','7068');
$result = array_filter(
$array,
function ($number) {
return !preg_match('/(.).*''1/', $number);
}
);
echo implode(', ', $result), PHP_EOL;
输出:
8397, 9652, 4378, 8431, 5349, 7068
这应该适用于您:
这里,我首先将str_split()
的每个元素与array_map()
组成单独的阵列。在这之后,我只是将拆分的数组与仅具有array_unique()
数字的相同数组进行比较,并检查它们是否相同。如果是,则返回implode()
编号,否则为false。最后,我只过滤掉带有false的元素,去掉array_filter()
。
换句话说,我只是比较这两个阵列,它们是相同的:
阵列1:
Array
(
[0] => Array
(
[0] => 4
[1] => 1
[2] => 4
[3] => 9
)
//...
)
阵列2:
Array
(
[0] => Array
(
[0] => 4
[1] => 1
[3] => 9
)
//...
)
代码:
<?php
$arr = ['4149', '8397', '9652', '4378', '3199', '7999', '8431', '5349', '7068'];
$arr = array_map("str_split", $arr);
$result = array_filter(array_map(function($v1, $v2){
return ($v1 === $v2?implode("", $v1):false);
}, $arr, array_map("array_unique", $arr)));
print_r($result);
?>
输出:
Array ( [1] => 8397 [2] => 9652 [3] => 4378 [6] => 8431 [7] => 5349 [8] => 7068 )