Search a 2D Matrix II

Source

Write an efficient algorithm that searches for a
value in an m x n matrix, return the occurrence of it.

This matrix has the following properties:

Integers in each row are sorted from left to right.
Integers in each column are sorted from up to bottom.
No duplicate integers in each row or column.

Example
Consider the following matrix:

[
  [1, 3, 5, 7],
  [2, 4, 7, 8],
  [3, 5, 9, 10]
]
Given target = 3, return 2.

Challenge
O(m+n) time and O(1) extra space

Python

class Solution:
    """
    @param matrix: An list of lists of integers
    @param target: An integer you want to search in matrix
    @return: An integer indicates the total occurrence of target in the given matrix
    """
    def searchMatrix(self, matrix, target):
        if not matrix or not matrix[0]:
            return 0

        row=0
        col=len(matrix[0])-1
        occur=0

        while row<len(matrix) and col>=0:
            if matrix[row][col]==target:
                occur+=1
                col-=1
            elif matrix[row][col]<target:
                row+=1
            else:
                col-=1
        return occur