[백준]행렬 덧셈

Sooin Yoon·2025년 4월 23일
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)

0개의 댓글