Number of Senior Citizens | LeetCode 2678 | C

2023-08-30
LeetCode

You are given a 0-indexed array of strings details. Each element of details provides information about a given passenger compressed into a string of length 15. The system is such that:

The first ten characters consist of the phone number of passengers.
The next character denotes the gender of the person.
The following two characters are used to indicate the age of the person.
The last two characters determine the seat allotted to that person.
Return the number of passengers who are strictly more than 60 years old.

Example 1:

1
2
3
Input: details = ["7868190130M7522","5303914400F9211","9273338290F4010"]
Output: 2
Explanation: The passengers at indices 0, 1, and 2 have ages 75, 92, and 40. Thus, there are 2 people who are over 60 years old.

Example 2:

1
2
3
Input: details = ["1313579440F2036","2921522980M5644"]
Output: 0
Explanation: None of the passengers are older than 60.

Constraints:

1
2
3
4
5
1 <= details.length <= 100
details[i].length == 15
details[i] consists of digits from '0' to '9'.
details[i][10] is either 'M' or 'F' or 'O'.
The phone numbers and seat numbers of the passengers are distinct.

Approach

1
Find the two characters that are used to indicate the age of the person and check if they are strictly more than 60 years old.

Algorithm

1
2
3
1. Get the two letters.
2. Check if the person is strictly more than 60 years old.
3. Increase the counter if yes.

Implementation

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
int countSeniors(char ** details, int detailsSize){
int count = 0;
for(int i=0;i<detailsSize;i++)
{
if(details[i][11]-'6' > 0)
{
count++;
continue;
}
if(details[i][11]-'6' >= 0 && details[i][12]-'0' >0)
{
count++;
}
}
return count;
}