zoukankan      html  css  js  c++  java
  • PHP统计所有字符在字符串中出现的次数

     1 <?php  
     2 //统计字符串中出现的字符,出现次数  
     3 echo '<pre>';  
     4 $str = 'aaabbccqqwweedfghhjffffffffggggggggg';//字符串示例  
     5 echo $str.'<br/>';  
     6 $strRecord=array();//把出现过的字符记录在此数组中,如果记录有,则不记录,  
     7   
     8 for($i=0;$i<strlen($str);$i++){  
     9     $found = 0;//默认设置为没有遇到过  
    10   
    11     foreach((array)$strRecord as $k=>$v){  
    12         if($str[$i] == $v['key']){  
    13             $strRecord[$k]['count'] += 1;//已经遇到,count + 1;  
    14             $found = 1;//设置已经遇到过的,标记  
    15             continue;//如果已经遇到,不用再循环记录数组了,继续下一个字符串比较  
    16         }  
    17     }  
    18   
    19     if(!$found){  
    20         $strRecord[] = array('key'=>$str[$i],'count'=>1);//记录没有遇到过的字符串  
    21     }  
    22 }  
    23 print_r($strRecord);  



    效果如图

    算法

    循环一次字符串(本例的$str),把出现过的字符串记录在一个数组(如本例的$strRecord)内,如果已经此记录函数已经有,则不记录;

    在每个字符串时,拿来与记录数组的值进行比较(本例的$strRecord[]['key']),如果记录里的某个值和这个字符串一样,就记录次数+1(本例的$strRecord[]['count']);

    当然,设置一个变量,默认为false(如本例的$found),记录每次比较完,如果记录数组已经有这个值,就设置为true,通过这个标记,把没有遇到过的数组记录到数组里

    代码:

  • 相关阅读:
    sonarque下载和安装使用
    npm install appium
    WIn10 电脑运行Docker
    AngularJs Type error : Cannot read property 'childNodes' of undefined
    Angular ui-route介绍
    Thymeleaf的模板使用介绍
    IntelliJ IDEA IDEA 2018 激活注册码
    session和cookies
    springmvc中的拦截器interceptor用法
    实现mapper接口注入的两种方式,以及后台的使用区别
  • 原文地址:https://www.cnblogs.com/datang6777/p/6957118.html
Copyright © 2011-2022 走看看