|
<?php
//這個(gè)方法純粹是背函數(shù),不解釋;
function countStr($str){
$str_array=str_split($str);
$str_array=array_count_values($str_array);
arsort($str_array);
return $str_array;
}
//以下是例子;
$str="asdfgfdas323344##$/$fdsdfg*$**$*$**$$443563536254fas";
print_r(countStr($str));
?>
<?
//這個(gè)方法有些數(shù)據(jù)結(jié)構(gòu)的思想,不過(guò)還是很好理解的:)
function countStr2($str){
$str_array=str_split($str);
$result_array=array();
foreach($str_array as $value){//判斷該字符是否是新出現(xiàn)的種類,是的話就設(shè)置為1,不是的話就自加;
if(!$result_array[$value]){
$result_array[$value]=1;
}else{
$result_array[$value]++;
}
}
arsort($result_array);
return $result_array;
}
$str="asdfgfdas323344##$/$fdsdfg*$**$*$**$$443563536254fas";
var_dump(countStr2($str))
?>
<?php
//這個(gè)方法純粹是解法一的蹩腳版本,先找出所有字符的總類,然后在一個(gè)一個(gè)用substr_count函數(shù)統(tǒng)計(jì)。
function countStr3($str){
$str_array=str_split($str);
$unique=array_unique($str_array);
foreach ($unique as $v){
$result_array[$v]=substr_count($str,$v);
}
arsort($result_array);
return $result_array;
}
$str="asdfgfdas323344##$/$fdsdfg*$**$*$**$$443563536254fas";
var_dump(countStr3($str));
?>
*無(wú)論是用哪一個(gè)方法,都要用到str_split函數(shù),所以說(shuō),這個(gè)函數(shù)很重要哦~
php技術(shù):php中3種方法統(tǒng)計(jì)字符串中每種字符的個(gè)數(shù)并排序,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。