LeetCode in Kotlin

3136. Valid Word

Easy

A word is considered valid if:

You are given a string word.

Return true if word is valid, otherwise, return false.

Notes:

Example 1:

Input: word = “234Adas”

Output: true

Explanation:

This word satisfies the conditions.

Example 2:

Input: word = “b3”

Output: false

Explanation:

The length of this word is fewer than 3, and does not have a vowel.

Example 3:

Input: word = “a3$e”

Output: false

Explanation:

This word contains a '$' character and does not have a consonant.

Constraints:

Solution

class Solution {
    fun isValid(word: String): Boolean {
        if (word.length < 3) {
            return false
        }
        if (word.contains("@") || word.contains("#") || word.contains("$")) {
            return false
        }
        val vowels = charArrayOf('a', 'e', 'i', 'o', 'u', 'A', 'E', 'I', 'O', 'U')
        val consonants = charArrayOf(
            'b', 'c', 'd', 'f', 'g', 'h', 'j', 'k', 'l', 'm', 'n', 'p', 'q', 'r', 's', 't', 'v',
            'w', 'x', 'y', 'z', 'B', 'C', 'D', 'F', 'G', 'H', 'J', 'K', 'L', 'M', 'N', 'P', 'Q',
            'R', 'S', 'T', 'V', 'W', 'X', 'Y', 'Z',
        )
        var flag1 = false
        var flag2 = false
        for (c in vowels) {
            if (word.indexOf(c) != -1) {
                flag1 = true
                break
            }
        }
        for (c in consonants) {
            if (word.indexOf(c) != -1) {
                flag2 = true
                break
            }
        }
        return flag1 && flag2
    }
}