3種方法,統計字串中每種字元的個數並排序,多種解法喲~ str_split()函數很重要
代碼如下:
<?php //這個方法純粹是背函數,不解釋; 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)); ?>
<? //這個方法有些資料結構的思想,不過還是很好理解的:) function countStr2($str){ $str_array=str_split($str); $result_array=array(); foreach($str_array as $value){//判斷該字元是否是新出現的種類,是的話就設定為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 //這個方法純粹是解法一的蹩腳版本,先找出所有字元的總類,然後在一個一個用substr_count函數統計。 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)); ?>
*無論是用哪一個方法,都要用到str_split函數,所以說,這個函數很重要哦~