php教程

超轻量级php框架startmvc

PHP获取字符流中第一个不重复字符的方法

更新时间:2020-03-26 01:20:40 作者:startmvc
本文实例讲述了PHP获取字符流中第一个不重复字符的方法。分享给大家供大家参考,具体如

本文实例讲述了PHP获取字符流中第一个不重复字符的方法。分享给大家供大家参考,具体如下:

问题

请实现一个函数用来找出字符流中第一个只出现一次的字符。例如,当从字符流中只读出前两个字符”go”时,第一个只出现一次的字符是”g”。当从该字符流中读出前六个字符“google”时,第一个只出现一次的字符是”l”。 输出描述: 如果当前字符流没有存在出现一次的字符,返回#字符

题解

使用索引数组

实现代码


<?php
global $result;
//Init module if you need
function Init(){
 global $result;
 $result = [];
}
//Insert one char from stringstream
function Insert($ch)
{
 global $result;
 // write code here
 if(isset($result[$ch])){
 $result[$ch]++;
 }else{
 $result[$ch] =1; 
 }
}
//return the first appearence once char in current stringstream
function FirstAppearingOnce()
{
 global $result;
 foreach($result as $k =>$v){
 if($v ==1){
 return $k;
 }
 }
 return "#";
}

PHP 字符流 第一个 不重复字符