Leetcode - find-n-unique-integers-sum-up-to-zero
Leetcode - subarray-product-less-than-k

Leetcode - The K Weakest Rows in a Matrix

violet posted @ 5 年前 in 算法 with tags Algorithm array Heap Golang , 591 阅读

https://leetcode.com/problems/the-k-weakest-rows-in-a-matrix/

Given a m * n matrix mat of ones (representing soldiers) and zeros (representing civilians), return the indexes of the k weakest rows in the matrix ordered from the weakest to the strongest.

A row i is weaker than row j, if the number of soldiers in row i is less than the number of soldiers in row j, or they have the same number of soldiers but i is less than j. Soldiers are always stand in the frontier of a row, that is, always ones may appear first and then zeros.

Example 1:

Input: mat = 
[[1,1,0,0,0],
 [1,1,1,1,0],
 [1,0,0,0,0],
 [1,1,0,0,0],
 [1,1,1,1,1]], 
k = 3
Output: [2,0,3]
Explanation: 
The number of soldiers for each row is: 
row 0 -> 2 
row 1 -> 4 
row 2 -> 1 
row 3 -> 2 
row 4 -> 5 
Rows ordered from the weakest to the strongest are [2,0,3,1,4]

I'm considering to use heap here. Build a heap and then pop k times.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
type row struct {
    count int
    index int
}
type rowHeap []row
 
func (h rowHeap) Len() int { return len(h) }
func (h rowHeap) Less(i, j int) bool {
    if h[i].count < h[j].count {
        return true
    } else if h[i].count == h[j].count {
        if h[i].index < h[j].index {
            return true
        } else {
            return false
        }
    }
    return false
}
func (h rowHeap) Swap(i, j int) { h[i], h[j] = h[j], h[i] }
 
func (h *rowHeap) Push(x interface{}) {
    // Push and Pop use pointer receivers because they modify the slice's length,
    // not just its contents.
    *h = append(*h, x.(row))
}
 
func (h *rowHeap) Pop() interface{} {
    old := *h
    n := len(old)
    x := old[n-1]
    *h = old[0 : n-1]
    return x
}
 
func kWeakestRows(mat [][]int, k int) []int {
    h := make(rowHeap, len(mat))
    for i, m := range mat {
        h[i] = row{
            count: sum(m),
            index: i,
        }
    }
 
    heap.Init(&h)
    result := []int{}
    for i := 0; i < k; i++ {
        result = append(result, heap.Pop(&h).(row).index)
    }
 
    return result
}
 
func sum(num []int) int {
    result := 0
    for _, n := range num {
        result += n
    }
    return result
}

 

Patna Escorts Servic 说:
2 年前

I'm extremely stunned after seen your best help. be caring your data sharing you truly awesome work posting

Call Girls Service i 说:
大约 1 年前

If you are looking for Bangalore Escorts Service then visit our site. If you are a person who is looking for a good time with Bangalore Escorts company, then we can help you out. We have many best and most beautiful girls in the city of Bangalore who will provide this type of service on your behalf. Our beautiful escorts in Bangalore best meet your requirements and match your expectations perfectly.


登录 *


loading captcha image...
(输入验证码)
or Ctrl+Enter