문제
풀이
- 2차원 list를 입력받은것을 전치행렬로 trans 한 후, count가 1인 요소만 더해서 반환하면 구현할수 있다.
코드
import sys
input = sys.stdin.readline
def solve(nums: list) -> str:
trans, filter_l, result = [], [], []
for x in range(3):
l = []
for y in nums:
l.append(y[x])
trans.append(l)
for x in trans:
l = []
for y in x:
if x.count(y) == 1:
l.append(y)
else:
l.append(0)
filter_l.append(l)
result = list(zip(filter_l[0], filter_l[1], filter_l[2]))
return '\n'.join(map(str, [sum(x) for x in result]))
if __name__ == '__main__':
n = int(input())
nums = [list(map(int, input().split())) for _ in range(n)]
print(solve(nums))
결과
출처 & 깃허브
boj 5533
GITHUB