题目描述
小易喜欢的单词具有以下特性:
1.单词每个字母都是大写字母
2.单词没有连续相等的字母
3.单词没有形如“xyxy”(这里的x,y指的都是字母,并且可以相同)这样的子序列,子序列可能不连续。
例如:
小易不喜欢"ABBA",因为这里有两个连续的'B'
小易不喜欢"THETXH",因为这里包含子序列"THTH"
小易不喜欢"ABACADA",因为这里包含子序列"AAAA"
小易喜欢"A","ABA"和"ABCBA"这些单词
给你一个单词,你要回答小易是否会喜欢这个单词。
1.单词每个字母都是大写字母
2.单词没有连续相等的字母
3.单词没有形如“xyxy”(这里的x,y指的都是字母,并且可以相同)这样的子序列,子序列可能不连续。
例如:
小易不喜欢"ABBA",因为这里有两个连续的'B'
小易不喜欢"THETXH",因为这里包含子序列"THTH"
小易不喜欢"ABACADA",因为这里包含子序列"AAAA"
小易喜欢"A","ABA"和"ABCBA"这些单词
给你一个单词,你要回答小易是否会喜欢这个单词。
输入描述:
输入为一个字符串,都由大写字母组成,长度小于100
输出描述:
如果小易喜欢输出"Likes",不喜欢输出"Dislikes"
思路:已经很清晰了,只要把输入的字符串进行3个条件的过滤就好了。
代码:
package net.stxy.one; import java.util.Scanner; /** * Created by ASUS on 2018/6/22 * * @Authod Grey Wolf */ public class Test { public static void main(String[] args) { Test test=new Test(); test.sys(); } private void sys() { Scanner scanner=new Scanner(System.in); while (scanner.hasNext()){ String str=scanner.nextLine(); if (getRes(str)){ System.out.println("Likes"); }else { System.out.println("Dislikes"); } } scanner.close(); } private boolean getRes(String str) { char []chars=str.toCharArray(); int i; int len=chars.length; //判断是否字母大小写,条件1 for (i=0;i<len;i++){ if (chars[i]<'A'||chars[i]>'Z'){ return false; } } //判断字母是否重复,条件2,3 for (i=1;i<len;i++){ if (chars[i]==chars[i-1]){ return false; } } return true; } }
效果:
AAA
Dislikes
ABA
Likes
ABCBA
Likes
我的座右铭:不会,我可以学;落后,我可以追赶;跌倒,我可以站起来;我一定行。