https://www.acmicpc.net/problem/2738
첫째 줄에 행렬의 크기 N 과 M이 주어진다. 둘째 줄부터 N개의 줄에 행렬 A의 원소 M개가 차례대로 주어진다. 이어서 N개의 줄에 행렬 B의 원소 M개가 차례대로 주어진다. N과 M은 100보다 작거나 같고, 행렬의 원소는 절댓값이 100보다 작거나 같은 정수이다.
lines = [
"3 3",
"1 1 1",
"2 2 2",
"0 1 0",
"3 3 3",
"4 4 4",
"5 5 100"
]
n,m = map(int, lines[0].split())
A = []
for i in range(1, 1+n):
A.append(lines[i].split())
B = []
for i in range(1+n, 1+n+n):
B.append(lines[i].split())
result = []
for i in range(n):
row = []
for j in range(m):
row.append(int(A[i][j]) + int(B[i][j]))
result.append(row)
result
for row in result:
print(*row)
몰랐던 건 * row를 쓰면 리스트가 언팩되어서 넘기는 역할
row = [1,2,3]
print(*row)
<<< 1,2,3
리스트 내포구문으로 짧게 나타내면
n.m = map(int, input().split())
A =[list(map(int, input().split())) for _ in range(n)]
B =[list(map(int, input().split())) for _ in range(n)]
for i in range(n):
row = [int(A[i][j]) + int(B[i][j]) for j in range(m)]
print(*row)