본문 바로가기
Algorithm Problem Solving/BaekJoon

[BaekJoon] 백준 10798 세로읽기 (Python / 파이썬)

by ʚ⇜❅🎕̈❄⇝ɞ 2021. 8. 17.
728x90
반응형

BaekJoon 백준 10798 세로 읽기 문제는 한 줄의 단어는 글자들을 빈칸 없이 연속으로 나열해서 최대 15개의 글자들로 이루어진다. 칠판에 만들어진 다섯 개의 단어를 세로로 읽을 때, 세로로 읽은 순서대로 글자들을 공백 없이 출력하는 문제이다. 난이도는 Bronze 1이다.

 

BaekJoon 10798 세로 읽기 문제 정보

출처

- https://www.acmicpc.net/problem/10798

난이도

- 브론즈 1 / Bronze 1

 

세로 읽기 문제 요약

  • 장난감에 있는 글자들은 영어 대문자 ‘A’부터 ‘Z’, 영어 소문자 ‘a’부터 ‘z’, 숫자 ‘0’부터 ‘9’이다.
  • 칠판에 글자들을 수평으로 일렬로 붙여서 단어를 만든다. 다시 그 아래쪽에 글자들을 붙여서 또 다른 단어를 만든다. 이런 식으로 다섯 개의 단어를 만든다.
  • 한 줄의 단어는 글자들을 빈칸 없이 연속으로 나열해서 최대 15개의 글자들로 이루어진다. 또한 만들어진 다섯 개의 단어들의 글자 개수는 서로 다를 수 있다.
  • 칠판에 만들어진 다섯 개의 단어를 세로로 읽으려 한다. 세로로 읽을 때, 각 단어의 첫 번째 글자들을 위에서 아래로 세로로 읽는다. 다음에 두 번째 글자들을 세로로 읽는다. 이런 식으로 왼쪽에서 오른쪽으로 한 자리씩 이동하면서 동일한 자리의 글자들을 세로로 읽어 나간다.
  • 세로로 읽을 때 해당 자리의 글자가 없으면, 읽지 않고 그다음 글자를 계속 읽는다.
  • 각 줄의 시작과 마지막에 빈칸은 없다.
  • 세로로 읽은 순서대로 글자들을 공백 없이 출력한다.

 

문제 풀이 과정

  1. 단어를 입력받을 때 단어의 길이도 함께 저장한다.
  2. 단어의 길이가 제일 긴 만큼 반복하고
  3. 단어의 수인 5 만큼 반복해서
  4. 해당 단어에 해당 번째의 글자가 있다면 결과 문자열에 추가한다.
  5. 세로로 읽은 순서대로 글자들을 출력한다.

 

코드 및 설명
words = []
length = []
for _ in range(5):
    word = input()
    words.append(word)
    length.append(len(word))

rst = ''
for i in range(max(length)):
    for j in range(5):
        if i < length[j]:
            rst += words[j][i]

print(rst)

BaekJoon 백준 10798 세로 읽기 문제를 파이썬 python으로 풀어보았다. 난이도는 Bronze 브론즈 1이다. 

728x90
반응형

댓글