So, I do not understand why it is $O(n)$ running time in the case when we have some $n$ elements and with each recursive call we separate our array by half and we continue working only on a one half (considering that each recursive call requires comparisons with each elements in a sub-array). Is it some sequence? How to express it in a mathematical way? I guess we can express this recurrence as $T(n) = T(n/2) + O(n)$
Thanks!