您的位置:首页 > 其它

算法题--小易喜欢的单词

2017-09-17 16:58 190 查看


题目描述

小易喜欢的单词具有以下特性:

1.单词每个字母都是大写字母

2.单词没有连续相等的字母

3.单词没有形如“xyxy”(这里的x,y指的都是字母,并且可以相同)这样的子序列,子序列可能不连续。

例如:

小易不喜欢"ABBA",因为这里有两个连续的'B'

小易不喜欢"THETXH",因为这里包含子序列"THTH"

小易不喜欢"ABACADA",因为这里包含子序列"AAAA"

小易喜欢"A","ABA"和"ABCBA"这些单词

给你一个单词,你要回答小易是否会喜欢这个单词。

<?php
$handler = fopen('php://stdin','r');
$str = trim(fgets($handler));
fclose($handler);
if (judge1($str) && judge2($str) && judge3($str)) {
echo 'Likes';
} else {
echo 'Dislikes';
}
function judge1($str) {
//判断是否大写
for ($i=0;$i<strlen($str);$i++) {
if (65>ord($str[$i]) || ord($str[$i])>90) {
return false;
}
}
return true;
}
function judge2($str) {
//判断单词有没有连续的字母
for ($i=0;$i<strlen($str)-1;$i++) {
if ($str[$i] == $str[$i+1]) {
return false;
}
}
return true;
}
function judge3($str) {
//判断有没有xyxy子序列
$pattern = '/.*(\w).*(\w).*(.*\\1).*(.*\\2)/';
$res = preg_match($pattern, $str);
return !$res;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: