###### tags: `leetcode` `easy` `String` `Counting`
# [1704. Determine if String Halves Are Alike](https://leetcode.com/problems/determine-if-string-halves-are-alike/)
## Description
You are given a string `s` of even length. Split this string into two halves of equal lengths, and let `a` be the first half and `b` be the second half.
Two strings are **alike** if they have the same number of vowels (`'a'`, `'e'`, `'i'`, `'o'`, `'u'`, `'A'`, `'E'`, `'I'`, `'O'`, `'U'`). Notice that s contains uppercase and lowercase letters.
Return `true` if `a` and `b` are **alike**. Otherwise, return `false`.
## Examples
### Example 1:
**Input**: s = "book"
**Output**: true
**Explanation**: a = "bo" and b = "ok". a has 1 vowel and b has 1 vowel. Therefore, they are alike.
### Example 2:
**Input**: s = "textbook"
**Output**: false
**Explanation**: a = "text" and b = "book". a has 1 vowel whereas b has 2. Therefore, they are not alike.
Notice that the vowel o is counted twice.
## Constraints:
- $2 \leq s.length \leq 1000$
- ``s.length`` is even.
- `s` consists of **uppercase and lowercase** letters.
## Code
```c=
int checkVowels(char *c){
if(*c == 'a')
return 1;
if(*c == 'e')
return 1;
if(*c == 'i')
return 1;
if(*c == 'o')
return 1;
if(*c == 'u')
return 1;
if(*c == 'A')
return 1;
if(*c == 'E')
return 1;
if(*c == 'I')
return 1;
if(*c == 'O')
return 1;
if(*c == 'U')
return 1;
return 0;
}
bool halvesAreAlike(char * s){
int length = strlen(s), count = 0;
for(int i = 0 ; i < length/2 ; i++)
count+=checkVowels(s+i);
for(int i = length/2 ; i < length ; i++)
count-=checkVowels(s+i);
if(!count)
return true;
return false;
}
```
## Complexity
|Space |Time |
|- |- |
|$O(1)$|$O(N)$|
## Result
- Runtime: 0 ms, faster than 100.00%
- Memory Usage: 5.9 MB, less than 31.58%