Skip to content

Commit

Permalink
Merge pull request #900 from 0xff-dev/3005
Browse files Browse the repository at this point in the history
Add solution and test-cases for problem 3005
  • Loading branch information
6boris authored Jun 14, 2024
2 parents 206dc0b + ea0e25b commit 82b4bea
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 23 deletions.
Original file line number Diff line number Diff line change
@@ -1,28 +1,29 @@
# [3005.Count Elements With Maximum Frequency][title]

> [!WARNING|style:flat]
> This question is temporarily unanswered if you have good ideas. Welcome to [Create Pull Request PR](https://github.com/kylesliu/awesome-golang-algorithm)
## Description
You are given an array `nums` consisting of **positive** integers.

Return the **total frequencies** of elements in `nums` such that those elements all have the **maximum** frequency.

The **frequency** of an element is the number of occurrences of that element in the array.

**Example 1:**

```
Input: a = "11", b = "1"
Output: "100"
Input: nums = [1,2,2,3,1,4]
Output: 4
Explanation: The elements 1 and 2 have a frequency of 2 which is the maximum frequency in the array.
So the number of elements in the array with maximum frequency is 4.
```

## 题意
> ...
**Example 2:**

## 题解

### 思路1
> ...
Count Elements With Maximum Frequency
```go
```

Input: nums = [1,2,3,4,5]
Output: 5
Explanation: All elements of the array have a frequency of 1 which is the maximum.
So the number of elements in the array with maximum frequency is 5.
```

## 结语

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,24 @@
package Solution

func Solution(x bool) bool {
return x
func Solution(nums []int) int {
count := make([]int, 101)
for _, n := range nums {
count[n]++
}

ans := 0
freq := -1
for _, c := range count {
if c == 0 {
continue
}
if c > freq {
ans = 0
freq = c
}
if c == freq {
ans += freq
}
}
return ans
}
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,11 @@ func TestSolution(t *testing.T) {
// 测试用例
cases := []struct {
name string
inputs bool
expect bool
inputs []int
expect int
}{
{"TestCase", true, true},
{"TestCase", true, true},
{"TestCase", false, false},
{"TestCase1", []int{1, 2, 2, 3, 1, 4}, 4},
{"TestCase2", []int{1, 2, 3, 4, 5}, 5},
}

// 开始测试
Expand All @@ -30,10 +29,10 @@ func TestSolution(t *testing.T) {
}
}

// 压力测试
// 压力测试
func BenchmarkSolution(b *testing.B) {
}

// 使用案列
// 使用案列
func ExampleSolution() {
}

0 comments on commit 82b4bea

Please sign in to comment.