復制代碼 代碼如下:
<?php
//這個方法純粹是背函數(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));
?>
<?
//這個方法有些數(shù)據(jù)結構的思想,不過還是很好理解的:)
function countStr2($str){
$str_array=str_split($str);
$result_array=array();
foreach($str_array as $value){//判斷該字符是否是新出現(xiàn)的種類,是的話就設置為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函數(shù)統(tǒng)計。
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));
?>
新聞熱點
疑難解答