나는 이렇게 학습한다/Algorithm & SQL

0921. Sum without highest and lowest number

daco2020 2022. 9. 21. 23:06
반응형

Task

Sum all the numbers of a given array ( cq. list ), except the highest and the lowest element ( by value, not by index! ).

The highest or lowest element respectively is a single element at each edge, even if there are more than one with the same value.

Mind the input validation.

Example

{ 6, 2, 1, 8, 10 } => 16
{ 1, 1, 11, 2, 3 } => 6

Input validation

If an empty value ( null, None, Nothing etc. ) is given instead of an array, or the given array is an empty list or a list with only 1 element, return 0.



Solution:

from typing import Optional, List


def sum_array(arr: Optional[List[int]]):
    return arr and sum(sorted(arr)[1:-1]) or 0


반응형