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

时间:2018-01-16

本文实例讲述了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相关内容感兴趣的读者可查看本站专题:《PHP数据结构与算法教程》、《php程序设计算法总结》、《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP常用遍历算法与技巧总结》及《PHP数学运算技巧总结》

希望本文所述对大家PHP程序设计有所帮助。

您可能感兴趣的文章:

  • php从数组中随机选择若干不重复元素的方法
  • PHP查找数值数组中不重复最大和最小的10个数的方法
  • php数组函数序列之array_unique() - 去除数组中重复的元素值
  • php array_flip() 删除数组重复元素
  • PHP n个不重复的随机数生成代码
  • php二维数组合并及去重复的方法
  • PHP两种去掉数组重复值的方法比较
  • PHP去除数组中重复的元素并按键名排序函数
  • php去除数组中重复数据
  • php去除重复字的实现代码
上一篇:浅谈php字符串反转 面试中经常遇到 下一篇:PHP利用一行代码删除目录下所有文件方法示例

相关文章

最新文章