From 76747ebd8cfc136b236653ae7ff8b658aa7092cd Mon Sep 17 00:00:00 2001 From: yanglbme Date: Fri, 28 Jan 2022 09:33:27 +0800 Subject: [PATCH] feat: add solutions to lc problem: No.1996 No.1996.The Number of Weak Characters in the Game --- .../README.md | 76 ++++++++++++++++++- .../README_EN.md | 65 +++++++++++++++- .../Solution.cpp | 14 ++++ .../Solution.go | 17 +++++ .../Solution.java | 15 ++++ .../Solution.py | 9 +++ 6 files changed, 194 insertions(+), 2 deletions(-) create mode 100644 solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.cpp create mode 100644 solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.go create mode 100644 solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.java create mode 100644 solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.py diff --git a/solution/1900-1999/1996.The Number of Weak Characters in the Game/README.md b/solution/1900-1999/1996.The Number of Weak Characters in the Game/README.md index 2ecfe71c2015a..cc82874482fd6 100644 --- a/solution/1900-1999/1996.The Number of Weak Characters in the Game/README.md +++ b/solution/1900-1999/1996.The Number of Weak Characters in the Game/README.md @@ -52,6 +52,12 @@ +按攻击力从大到小排序,攻击力相同则按防御力从小到大排序。 + +遍历,护遍历过的角色的防御的最大值 mx。 + +对于当前角色 p,如果 p 的防御小于 mx,说明前面有防御比 p 高的角色,记作 q。根据上面的排序规则,q 的攻击是大于或等于 p 的攻击的,如果 q 和 p 攻击相同,仍然根据上面的排序规则,q 的防御不会超过 p,矛盾,因此 q 的攻击必然大于 p,于是 q 的攻防均高于 p,p 是一个弱角色。 + ### **Python3** @@ -59,7 +65,15 @@ ```python - +class Solution: + def numberOfWeakCharacters(self, properties: List[List[int]]) -> int: + properties.sort(key=lambda x: (-x[0], x[1])) + ans = mx = 0 + for _, d in properties: + if mx > d: + ans += 1 + mx = max(mx, d) + return ans ``` ### **Java** @@ -67,7 +81,67 @@ ```java +class Solution { + + public int numberOfWeakCharacters(int[][] properties) { + Arrays.sort( + properties, + (a, b) -> { + return a[0] == b[0] ? a[1] - b[1] : b[0] - a[0]; + } + ); + int ans = 0, mx = 0; + for (int[] p : properties) { + if (mx > p[1]) { + ++ans; + } + mx = Math.max(mx, p[1]); + } + return ans; + } +} + +``` + +### **C++** + +```cpp +class Solution { +public: + int numberOfWeakCharacters(vector> &properties) { + sort(properties.begin(), properties.end(), [&](vector &a, vector &b) + { return a[0] == b[0] ? a[1] < b[1] : a[0] > b[0]; }); + int ans = 0, mx = 0; + for (auto &p : properties) + { + if (mx > p[1]) ++ans; + else mx = p[1]; + } + return ans; + } +}; +``` +### **Go** + +```go +func numberOfWeakCharacters(properties [][]int) int { + sort.Slice(properties, func(i, j int) bool { + if properties[i][0] == properties[j][0] { + return properties[i][1] < properties[j][1] + } + return properties[i][0] > properties[j][0] + }) + ans, mx := 0, 0 + for _, p := range properties { + if mx > p[1] { + ans++ + } else { + mx = p[1] + } + } + return ans +} ``` ### **...** diff --git a/solution/1900-1999/1996.The Number of Weak Characters in the Game/README_EN.md b/solution/1900-1999/1996.The Number of Weak Characters in the Game/README_EN.md index ee1781ed2f31a..89e26cdb85509 100644 --- a/solution/1900-1999/1996.The Number of Weak Characters in the Game/README_EN.md +++ b/solution/1900-1999/1996.The Number of Weak Characters in the Game/README_EN.md @@ -51,13 +51,76 @@ ### **Python3** ```python - +class Solution: + def numberOfWeakCharacters(self, properties: List[List[int]]) -> int: + properties.sort(key=lambda x: (-x[0], x[1])) + ans = mx = 0 + for _, d in properties: + if mx > d: + ans += 1 + mx = max(mx, d) + return ans ``` ### **Java** ```java +class Solution { + public int numberOfWeakCharacters(int[][] properties) { + Arrays.sort(properties, (a, b) -> { + return a[0] == b[0] ? a[1] - b[1] : b[0] - a[0]; + }); + int ans = 0, mx = 0; + for (int[] p : properties) { + if (mx > p[1]) { + ++ans; + } + mx = Math.max(mx, p[1]); + } + return ans; + } +} +``` + +### **C++** + +```cpp +class Solution { +public: + int numberOfWeakCharacters(vector> &properties) { + sort(properties.begin(), properties.end(), [&](vector &a, vector &b) + { return a[0] == b[0] ? a[1] < b[1] : a[0] > b[0]; }); + int ans = 0, mx = 0; + for (auto &p : properties) + { + if (mx > p[1]) ++ans; + else mx = p[1]; + } + return ans; + } +}; +``` +### **Go** + +```go +func numberOfWeakCharacters(properties [][]int) int { + sort.Slice(properties, func(i, j int) bool { + if properties[i][0] == properties[j][0] { + return properties[i][1] < properties[j][1] + } + return properties[i][0] > properties[j][0] + }) + ans, mx := 0, 0 + for _, p := range properties { + if mx > p[1] { + ans++ + } else { + mx = p[1] + } + } + return ans +} ``` ### **...** diff --git a/solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.cpp b/solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.cpp new file mode 100644 index 0000000000000..17940398b95cd --- /dev/null +++ b/solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.cpp @@ -0,0 +1,14 @@ +class Solution { +public: + int numberOfWeakCharacters(vector> &properties) { + sort(properties.begin(), properties.end(), [&](vector &a, vector &b) + { return a[0] == b[0] ? a[1] < b[1] : a[0] > b[0]; }); + int ans = 0, mx = 0; + for (auto &p : properties) + { + if (mx > p[1]) ++ans; + else mx = p[1]; + } + return ans; + } +}; \ No newline at end of file diff --git a/solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.go b/solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.go new file mode 100644 index 0000000000000..692744f0384c2 --- /dev/null +++ b/solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.go @@ -0,0 +1,17 @@ +func numberOfWeakCharacters(properties [][]int) int { + sort.Slice(properties, func(i, j int) bool { + if properties[i][0] == properties[j][0] { + return properties[i][1] < properties[j][1] + } + return properties[i][0] > properties[j][0] + }) + ans, mx := 0, 0 + for _, p := range properties { + if mx > p[1] { + ans++ + } else { + mx = p[1] + } + } + return ans +} \ No newline at end of file diff --git a/solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.java b/solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.java new file mode 100644 index 0000000000000..a86ba4001ee19 --- /dev/null +++ b/solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.java @@ -0,0 +1,15 @@ +class Solution { + public int numberOfWeakCharacters(int[][] properties) { + Arrays.sort(properties, (a, b) -> { + return a[0] == b[0] ? a[1] - b[1] : b[0] - a[0]; + }); + int ans = 0, mx = 0; + for (int[] p : properties) { + if (mx > p[1]) { + ++ans; + } + mx = Math.max(mx, p[1]); + } + return ans; + } +} \ No newline at end of file diff --git a/solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.py b/solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.py new file mode 100644 index 0000000000000..6cce1f2cddb3b --- /dev/null +++ b/solution/1900-1999/1996.The Number of Weak Characters in the Game/Solution.py @@ -0,0 +1,9 @@ +class Solution: + def numberOfWeakCharacters(self, properties: List[List[int]]) -> int: + properties.sort(key=lambda x: (-x[0], x[1])) + ans = mx = 0 + for _, d in properties: + if mx > d: + ans += 1 + mx = max(mx, d) + return ans