小易喜欢的单词具有以下特性:
1.单词每个字母都是大写字母
2.单词没有连续相等的字母
3.单词没有形如“xyxy”(这里的x,y指的都是字母,并且可以相同)这样的子序列,子序列可能不连续。
例如:
小易不喜欢"ABBA",因为这里有两个连续的'B'
小易不喜欢"THETXH",因为这里包含子序列"THTH"
小易不喜欢"ABACADA",因为这里包含子序列"AAAA"
小易喜欢"A","ABA"和"ABCBA"这些单词
给你一个单词,你要回答小易是否会喜欢这个单词(只要不是不喜欢,就是喜欢)。
输入描述:
输入为一个字符串,都由大写字母组成,长度小于100
输出描述:
如果小易喜欢输出"Likes",不喜欢输出"Dislikes"
示例1
输入
AAA
输出
Dislikes
题解参考西电的一位学长所写的代码。
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
String word = sc.next();
if(isAllUpCase(word) && isConEql(word) && isThrEql(word))
System.out.println("Likes");
else
System.out.println("Dislikes");
}
}
//条件1
public static boolean isAllUpCase(String word){
return word.matches("[A-Z]+");
}
//条件2
public static boolean isConEql(String word){
return !word.matches(".*(.)(\\1).*");
}
//条件3
public static boolean isThrEql(String word){
return !word.matches(".*(.).*(.)(.*\\1)(.*\\2).*");
}
}
神一般的正则表达式---
其中.表示匹配除换行符 \n 之外的任何单字符,(\1)表示引用第一个括号中的方法,相当于引用函数了,同理(\2)表示调用第二个括号中的函数。