ThirdMaximumNumber::thirdMax()   C
last analyzed

Complexity

Conditions 13
Paths 13

Size

Total Lines 23
Code Lines 16

Duplication

Lines 0
Ratio 0 %

Importance

Changes 2
Bugs 0 Features 0
Metric Value
eloc 16
c 2
b 0
f 0
dl 0
loc 23
rs 6.6166
cc 13
nc 13
nop 1

How to fix   Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php
2
3
declare(strict_types=1);
4
5
namespace leetcode;
6
7
class ThirdMaximumNumber
8
{
9
    public static function thirdMax(array $nums): int
10
    {
11
        if (empty($nums)) {
12
            return 0;
13
        }
14
        $a = $b = $c = null;
15
        foreach ($nums as $num) {
16
            if ($num === $a || $num === $b || $num === $c) {
17
                continue;
18
            }
19
            if ($a === null || $num > $a) {
20
                $c = $b;
21
                $b = $a;
22
                $a = $num;
23
            } elseif ($b === null || $num > $b) {
24
                $c = $b;
25
                $b = $num;
26
            } elseif ($c === null || $num > $c) {
27
                $c = $num;
28
            }
29
        }
30
31
        return $c === null ? $a : $c;
0 ignored issues
show
introduced by
The condition $c === null is always true.
Loading history...
32
    }
33
}
34