We use cookies (including Google cookies) to personalize ads and analyze traffic. By continuing to use our site, you accept our Privacy Policy.

Count Number of Teams

Difficulty: Medium


Problem Description

There are n soldiers standing in a line. Each soldier is assigned a unique rating value. You have to form a team of 3 soldiers amongst them under the following rules: Choose 3 soldiers with index (i, j, k) with rating (rating[i], rating[j], rating[k]). A team is valid if: (rating[i] < rating[j] < rating[k]) or (rating[i] > rating[j] > rating[k]) where (0 <= i < j < k < n). Return the number of teams you can form given the conditions. (soldiers can be part of multiple teams).


Key Insights

  • A valid team consists of three soldiers whose ratings are either strictly increasing or strictly decreasing.
  • For each soldier at position j, count how many soldiers to the left (i) and to the right (k) can form valid teams with j.
  • Use two nested loops to count potential team members for each soldier.

Space and Time Complexity

Time Complexity: O(n^2)
Space Complexity: O(1)


Solution

To solve this problem, we can use a brute-force approach where we iterate through each soldier as a potential middle member of a team. For each soldier at index j, we count how many soldiers to the left (i) can form a valid team with j and how many soldiers to the right (k) can also form a valid team. We accumulate the count of valid combinations based on the conditions given for increasing and decreasing sequences.


Code Solutions

def countTeams(rating):
    n = len(rating)
    count = 0
    
    for j in range(n):
        left_less = left_greater = 0
        right_less = right_greater = 0
        
        for i in range(j):
            if rating[i] < rating[j]:
                left_less += 1
            else:
                left_greater += 1
        
        for k in range(j + 1, n):
            if rating[k] < rating[j]:
                right_less += 1
            else:
                right_greater += 1
        
        count += left_less * right_greater + left_greater * right_less
    
    return count
← Back to All Questions