백준 7단계 코딩테스트

릿·2023년 2월 27일
0

코딩테스트

목록 보기
27/27

1. 행렬 덧셈

문제: N*M크기의 두 행렬 A와 B가 주어졌을 때, 두 행렬을 더하는 프로그램을 작성하시오.

입력: 첫째 줄에 행렬의 크기 N 과 M이 주어진다. 둘째 줄부터 N개의 줄에 행렬 A의 원소 M개가 차례대로 주어진다. 이어서 N개의 줄에 행렬 B의 원소 M개가 차례대로 주어진다. N과 M은 100보다 작거나 같고, 행렬의 원소는 절댓값이 100보다 작거나 같은 정수이다.

출력: 첫째 줄부터 N개의 줄에 행렬 A와 B를 더한 행렬을 출력한다. 행렬의 각 원소는 공백으로 구분한다.

1. 내 풀이

하나의 2차원 배열을 만든 뒤에 더해야하는 배열을 만든 2차원 배열값과 합쳐준 후 print했다.

n, m = map(int, input().split())
li = []

for i in range(n) :
    tmpLi = list(map(int, input().split()))
    li.append(tmpLi)

for i in range(n) :
    tmpLi = list(map(int, input().split()))
    for j in range(m) :
        li[i][j] = li[i][j] + tmpLi[j]
        print(li[i][j], end=' ')
    print()

2. 최댓값

문제: <그림 1>과 같이 9×9 격자판에 쓰여진 81개의 자연수 또는 0이 주어질 때, 이들 중 최댓값을 찾고 그 최댓값이 몇 행 몇 열에 위치한 수인지 구하는 프로그램을 작성하시오.
예를 들어, 다음과 같이 81개의 수가 주어지면

이들 중 최댓값은 90이고, 이 값은 5행 7열에 위치한다.

입력: 첫째 줄부터 아홉 번째 줄까지 한 줄에 아홉 개씩 수가 주어진다. 주어지는 수는 100보다 작은 자연수 또는 0이다.

출력: 첫째 줄에 최댓값을 출력하고, 둘째 줄에 최댓값이 위치한 행 번호와 열 번호를 빈칸을 사이에 두고 차례로 출력한다. 최댓값이 두 개 이상인 경우 그 중 한 곳의 위치를 출력한다.

1. 내 풀이

채점 중에 90프로쯤 되면 틀렸다고 나와서 구글링해보니 if문에 'maxVal보다 li[j]가 크면'이 아니라, 'maxVal보다 li[j]가 크거나 같으면'이어야 한단다. 으잉?...

maxVal = 0
maxColumn = 0
maxRow = 0

for i in range(9) :
    li = list(map(int, input().split()))
    for j in range(9) :
        if maxVal <= li[j] :
            maxVal = li[j]
            maxColumn = i+1
            maxRow = j+1

print(maxVal)
print(maxColumn, maxRow)

3. 세로읽기

문제: 아직 글을 모르는 영석이가 벽에 걸린 칠판에 자석이 붙어있는 글자들을 붙이는 장난감을 가지고 놀고 있다.

이 장난감에 있는 글자들은 영어 대문자 ‘A’부터 ‘Z’, 영어 소문자 ‘a’부터 ‘z’, 숫자 ‘0’부터 ‘9’이다. 영석이는 칠판에 글자들을 수평으로 일렬로 붙여서 단어를 만든다. 다시 그 아래쪽에 글자들을 붙여서 또 다른 단어를 만든다. 이런 식으로 다섯 개의 단어를 만든다. 아래 그림 1은 영석이가 칠판에 붙여 만든 단어들의 예이다.

<그림 1>

한 줄의 단어는 글자들을 빈칸 없이 연속으로 나열해서 최대 15개의 글자들로 이루어진다. 또한 만들어진 다섯 개의 단어들의 글자 개수는 서로 다를 수 있다.

심심해진 영석이는 칠판에 만들어진 다섯 개의 단어를 세로로 읽으려 한다. 세로로 읽을 때, 각 단어의 첫 번째 글자들을 위에서 아래로 세로로 읽는다. 다음에 두 번째 글자들을 세로로 읽는다. 이런 식으로 왼쪽에서 오른쪽으로 한 자리씩 이동 하면서 동일한 자리의 글자들을 세로로 읽어 나간다. 위의 그림 1의 다섯 번째 자리를 보면 두 번째 줄의 다섯 번째 자리의 글자는 없다. 이런 경우처럼 세로로 읽을 때 해당 자리의 글자가 없으면, 읽지 않고 그 다음 글자를 계속 읽는다. 그림 1의 다섯 번째 자리를 세로로 읽으면 D1gk로 읽는다.

그림 1에서 영석이가 세로로 읽은 순서대로 글자들을 공백 없이 출력하면 다음과 같다:

Aa0aPAf985Bz1EhCz2W3D1gkD6x

칠판에 붙여진 단어들이 주어질 때, 영석이가 세로로 읽은 순서대로 글자들을 출력하는 프로그램을 작성하시오.

입력: 총 다섯줄의 입력이 주어진다. 각 줄에는 최소 1개, 최대 15개의 글자들이 빈칸 없이 연속으로 주어진다. 주어지는 글자는 영어 대문자 ‘A’부터 ‘Z’, 영어 소문자 ‘a’부터 ‘z’, 숫자 ‘0’부터 ‘9’ 중 하나이다. 각 줄의 시작과 마지막에 빈칸은 없다.

출력: 영석이가 세로로 읽은 순서대로 글자들을 출력한다. 이때, 글자들을 공백 없이 연속해서 출력한다.

1. 내 풀이

처음엔 이렇게 썼다가 다시 문제를 읽어보니 매 행마다 단어 갯수가 다를 때도 있다고 함.

li = []

for i in range(5) :
    tmpLi = list(input())
    li.append(tmpLi)

for i in range(len(li[0])) :
    for j in range(len(li)) :
        print(li[j][i], end='')

그래서 입력받은 문자열 중에 maxLen을 구해주고 for문 돌려서 에러가 나면 피해가게 짬!

li = []
maxLen = 0

for i in range(5) :
    tmpLi = list(input())
    if maxLen < len(tmpLi) : maxLen = len(tmpLi)
    li.append(tmpLi)
    

for i in range(maxLen) :
    for j in range(len(li)) :
        try :
            print(li[j][i], end='')
        except:
            continue
profile
항상 재밌는 뭔가를 찾고 있는 프론트엔드 개발자

0개의 댓글