Skip to content

Latest commit

 

History

History

1996. The Number of Weak Characters in the Game

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 

Problem #1996 (The Number of Weak Characters in the Game | Array, Greedy, Monotonic Stack, Sorting, Stack)

You are playing a game that contains multiple characters, and each of the characters has two main properties: attack and defense. You are given a 2D integer array properties where properties[i] = [attackᵢ, defenseⱼ] represents the properties of the iᵗʰ character in the game.

A character is said to be weak if any other character has both attack and defense levels strictly greater than this character's attack and defense levels. More formally, a character i is said to be weak if there exists another character j where attackⱼ > attackᵢ and defenseⱼ > defenseᵢ.

Return the number of weak characters.

Example 1

Input:

properties = [[5,5],[6,3],[3,6]]

Output:

0

Explanation:

No character has strictly greater attack and defense than the other.

Example 2

Input:

properties = [[2,2],[3,3]]

Output:

1

Explanation:

The first character is weak because the second character has a strictly greater attack and defense.

Example 3

Input:

properties = [[1,5],[10,4],[4,3]]

Output:

1

Explanation:

The third character is weak because the second character has a strictly greater attack and defense.

Constraints

  • 2 <= properties.length <= 105
  • properties[i].length == 2
  • 1 <= attacki, defensei <= 105

Solutions

Sorting

Codes

  • Java
class Solution {
    public int numberOfWeakCharacters(int[][] properties) {
        int n = properties.length;
        int count = 0;
        int maxN = Integer.MIN_VALUE;
        Arrays.sort(properties, (a, b) -> a[0] == b[0] ? a[1] - b[1] : b[0] - a[0]);
        for(int i = 0; i < n; i++){
            if(properties[i][1] < maxN)
                count++;
            maxN = Math.max(maxN, properties[i][1]);
        }
        return count;
    }
}

image

  • C++
class Solution {
public:
    static bool compare(vector<int>& a, vector<int>& b){
        if(a[0] == b[0])
            return a[1] < b[1];
        return a[0] > b[0];
    }
    
    int numberOfWeakCharacters(vector<vector<int>>& properties) {
        int n = properties.size();
        int count = 0;
        int maxN = INT_MIN;
        sort(properties.begin(), properties.end(), compare);
        for(int i = 0; i < n; i++){
            if(properties[i][1] < maxN)
                count++;
            maxN = max(maxN, properties[i][1]);
        }
        return count;
    }
};

image

  • Python
class Solution(object):
    def numberOfWeakCharacters(self, properties):
        count = 0
        maxN = ~sys.maxint
        properties.sort(key=lambda x: (-x[0], x[1]))
        for i in range(len(properties)):
            if(properties[i][1] < maxN):
                count+=1
            maxN = max(maxN, properties[i][1])
        return count

image

Complexity

  • Time: O(n log n)
  • Space: O(n)