php数组数据结构 php7 数组( 三 )


Listing G
?php $data = https://www.04ip.com/post/array("book-1", "book-10", "book-100", "book-5"); sort($data);print_r($data);
natsort($data); print_r($data);?
它的输出结果如下:
Array ([0] = book-1
[1] = book-10
[2] = book-100
[3] = book-5
)
Array
(
[0] = book-1
[3] = book-5
[1] = book-10
[2] = book-100
)
它们的不同已经很清楚了:第二个排序结果更直观 , 更“人性化”,然而第一个则更符合算法规则,更具“计算机”特点 。
自然语言能进行倒排吗?答案是肯定的!只要对natsort()的结果使用array_reverse()函数就可以了,Listing H就是一个简单例子:
Listing H
?php $data = https://www.04ip.com/post/array("book-1", "book-10", "book-100", "book-5");natsort($data); print_r(array_reverse($data));
?
下面是它的输出结果:
Array ([0] = book-100
[1] = book-10
[2] = book-5
[3] = book-1
)
根据用户自定义的规则排序
PHP也能让你定义自己的排序算法,你可以通过创建你自己的比较函数,并把它传递给usort()函数 。如果第一个参数比第二个参数“小”的话,比较函数必须返回一个比0小的数 , 如果第一参数比第二个参数“大”的话,比较函数应该返回一个比0大的数 。
Listing I就是这样的一个例子 , 在这个例子中根据它们的长度对数组元素进行排序,最短的项放在最前面:
Listing I
?php $data = https://www.04ip.com/post/array("joe@host.com", "john.doe@gh.co.uk", "asmithsonian@us.info", "jay@zoo.tw");usort($data, 'sortByLen');
print_r($data); function sortByLen($a, $b) {
if (strlen($a) == strlen($b)) {
return 0;
} else {
return (strlen($a)strlen($b)) ? 1 : -1;
}
}
?
这样,就创建了我们自己的比较函数,这个函数使用strlen()函数比较每一个字符串的个数,然后分别返回1,0或-1.这个返回值是决定元素排列的基础 。下面是它的输出结果:
Array ([0] = jay@zoo.tw
[1] = joe@host.com
[2] = john.doe@gh.co.uk
[3] = asmithsonian@us.info
)
自然语言排序
PHP有一个非常独特的排序方式,这种方式使用认知而不是使用计算规则 。这种特性称为自然语言排序,当创建模糊逻辑应用软件的时候这种排序方式非常有用 。下面大家可以来看看它的一个简单例子,如Listing G所示:
Listing G
?php $data = https://www.04ip.com/post/array("book-1", "book-10", "book-100", "book-5"); sort($data);print_r($data);
natsort($data); print_r($data);?
它的输出结果如下:
Array ([0] = book-1
[1] = book-10
[2] = book-100
[3] = book-5
)
Array
(
[0] = book-1
[3] = book-5
[1] = book-10
[2] = book-100
)
它们的不同已经很清楚了:第二个排序结果更直观 , 更“人性化”,然而第一个则更符合算法规则,更具“计算机”特点 。
自然语言能进行倒排吗?答案是肯定的!只要对natsort()的结果使用array_reverse()函数就可以了,Listing H就是一个简单例子:
Listing H
?php $data = https://www.04ip.com/post/array("book-1", "book-10", "book-100", "book-5");natsort($data); print_r(array_reverse($data));
?
下面是它的输出结果:
Array ([0] = book-100
[1] = book-10
[2] = book-5
[3] = book-1
)
根据用户自定义的规则排序
PHP也能让你定义自己的排序算法,你可以通过创建你自己的比较函数,并把它传递给usort()函数 。如果第一个参数比第二个参数“小”的话,比较函数必须返回一个比0小的数,如果第一参数比第二个参数“大”的话,比较函数应该返回一个比0大的数 。

推荐阅读