编程题:小易喜欢的单词

题目描述

小易喜欢的单词具有以下特性:
1.单词每个字母都是大写字母
2.单词没有连续相等的字母
3.单词没有形如“xyxy”(这里的x,y指的都是字母,并且可以相同)这样的子序列,子序列可能不连续。
例如:
小易不喜欢"ABBA",因为这里有两个连续的'B'
小易不喜欢"THETXH",因为这里包含子序列"THTH"
小易不喜欢"ABACADA",因为这里包含子序列"AAAA"
小易喜欢"A","ABA"和"ABCBA"这些单词
给你一个单词,你要回答小易是否会喜欢这个单词。

输入描述:

输入为一个字符串,都由大写字母组成,长度小于100

输出描述:

如果小易喜欢输出"Likes",不喜欢输出"Dislikes"
示例1

输入

复制
AAA

输出

复制
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;i++){
            if (chars[i]<'A'||chars[i]>'Z'){
                return false;
            }
        }
        //判断字母是否重复,条件2,3
        for (i=1;i;i++){
            if (chars[i]==chars[i-1]){
                return false;
            }
        }
        return true;
    }


}

效果:

AAA
Dislikes
ABA
Likes
ABCBA
Likes


我的座右铭:不会,我可以学;落后,我可以追赶;跌倒,我可以站起来;我一定行。


你可能感兴趣的:(编程题)