2020-09-23 19:30:13 +08:00
|
|
|
from __future__ import annotations
|
2019-10-05 13:14:13 +08:00
|
|
|
|
2019-07-11 12:43:03 +08:00
|
|
|
|
2020-09-23 19:30:13 +08:00
|
|
|
def abs_max(x: list[int]) -> int:
|
2018-11-04 04:08:13 +08:00
|
|
|
"""
|
2019-07-11 12:43:03 +08:00
|
|
|
>>> abs_max([0,5,1,11])
|
2018-11-04 04:08:13 +08:00
|
|
|
11
|
2019-07-11 12:43:03 +08:00
|
|
|
>>> abs_max([3,-10,-2])
|
2018-11-04 04:08:13 +08:00
|
|
|
-10
|
|
|
|
"""
|
2019-10-05 13:14:13 +08:00
|
|
|
j = x[0]
|
2018-11-04 04:08:13 +08:00
|
|
|
for i in x:
|
2019-02-16 00:01:10 +08:00
|
|
|
if abs(i) > abs(j):
|
2018-11-04 04:08:13 +08:00
|
|
|
j = i
|
|
|
|
return j
|
2019-02-16 00:01:10 +08:00
|
|
|
|
2019-10-05 13:14:13 +08:00
|
|
|
|
2019-07-11 12:43:03 +08:00
|
|
|
def abs_max_sort(x):
|
|
|
|
"""
|
|
|
|
>>> abs_max_sort([0,5,1,11])
|
|
|
|
11
|
|
|
|
>>> abs_max_sort([3,-10,-2])
|
|
|
|
-10
|
|
|
|
"""
|
2019-10-05 13:14:13 +08:00
|
|
|
return sorted(x, key=abs)[-1]
|
|
|
|
|
2018-11-04 04:08:13 +08:00
|
|
|
|
|
|
|
def main():
|
2019-10-05 13:14:13 +08:00
|
|
|
a = [1, 2, -11]
|
2019-07-11 12:43:03 +08:00
|
|
|
assert abs_max(a) == -11
|
|
|
|
assert abs_max_sort(a) == -11
|
2018-11-04 04:08:13 +08:00
|
|
|
|
2018-12-05 01:18:32 +08:00
|
|
|
|
2019-10-05 13:14:13 +08:00
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|