본문 바로가기
프로그래밍 문제/[Python] CheckIO

[Check-IO] Absolute Sorting

by UltraLowTemp-Physics 2021. 11. 14.
반응형

[1] Problem: https://py.checkio.org/en/mission/absolute-sorting/

[2] Solution

def checkio(values: list) -> list:
    # your code here
    abs_sorted = sorted([abs(n) for n in values])
    answers = []
    for n in range(len(abs_sorted)):
        if not abs_sorted[n] in values: answers.append(- abs_sorted[n])
        else: answers.append(abs_sorted[n])
 
    return answers


if __name__ == '__main__':
    print("Example:")
    print(checkio([-20, -5, 10, 15]))

    # These "asserts" are used for self-checking and not for an auto-testing
    assert checkio([-20, -5, 10, 15]) == [-5, 10, 15, -20]
    assert checkio([1, 2, 3, 0]) == [0, 1, 2, 3]
    assert checkio([-1, -2, -3, 0]) == [0, -1, -2, -3]
    print("Coding complete? Click 'Check' to earn cool rewards!")

 

[3] Best Solutions

def checkio(numbers_array):
    """
    The magic of the key :)
    """
    return tuple(sorted(numbers_array, key=abs))

1) numbers_array를 절대값을 기준(key = abs)으로 정렬함
2) 하지만 왜 tuple을 적용하는지는 잘 모르겠음 

'프로그래밍 문제 > [Python] CheckIO' 카테고리의 다른 글

[Check-IO] Time converter  (0) 2021.12.10
[CheckIO] Goes Right After  (0) 2021.12.03
[Check-IO] Frequency Sorting  (0) 2021.04.18
[CheckIO] Median  (0) 2021.03.23
[CheckIO] Remove All After  (0) 2021.03.22

댓글