2 0 1 9 - 4 -22 星 期一 开 始 吧
上 一 题 链 接 Leetcode基础刷题之 PHP 解析(283. Move Zeroes)
题 目 描 述
给你两个字符串,判断他们是否遵循相同的模式。这就意味着你需要对字符串进行映射。
题 目 分 析
我这里的思路是,把第二次字符串分割成数组,每次从第一个字符串中截取一位进行映射,存入到自定义的数组中,首先判断的是如果字符串的长度和分割字符串的数组个数不相等,直接false,判断这个当前键是否存在数组中了,如果不存在还需要进一步判断当前的值是否等于已存在的键对应的值了,如果等于,说明当前值已经赋值给另外的键,直接false,如果当前键已经存在数组中,只需要判断当前值是否等于键中对应的值即可。
/** * @param String $pattern * @param String $str * @return Boolean */ function wordPattern($pattern, $str) { $data=[]; $strArray=explode(' ',$str); if(strlen($pattern) !==count($strArray)){ return false; } for($i=0;$i<count($strArray);$i++){ $current=substr($pattern,$i,1); if(!array_key_exists($current,$data)) { foreach($data as $key=>$val){ if($data[$key] ==$strArray[$i]) { return false; } } $data[$current]=$strArray[$i]; }else { if($data[$current] !==$strArray[$i]){ return false; } } } return true; }
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- Apache Flink 零基础入门(一):基础概念解析
- Apache Flink 零基础入门(一):基础概念解析
- JStorm 源码解析:基础线程模型
- React Hooks 解析(上):基础
- TypeScript基础入门之模块解析(一)
- TypeScript基础入门之模块解析(二)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。