본문 바로가기
  • < / >
Algorithm/Beakjoon

[백준] 10798 (C++)

by JunMango 2023. 5. 13.

 

제목세로읽기 

 

문제

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

<예제>
A A B C D D
a f z z
0 9 1 2 1
a 8 E W g 6
P 5 h 3 k x

한 줄의 단어는 글자들을 빈칸 없이 연속으로 나열해서 최대 15개의 글자들로 이루어진다. 또한 만들어진 다섯 개의 단어들의 글자 개수는 서로 다를 수 있다. 
심심해진 영석이는 칠판에 만들어진 다섯 개의 단어를 세로로 읽으려 한다. 세로로 읽을 때, 각 단어의 첫 번째 글자들을 위에서 아래로 세로로 읽는다. 다음에 두 번째 글자들을 세로로 읽는다. 이런 식으로 왼쪽에서 오른쪽으로 한 자리씩 이동 하면서 동일한 자리의 글자들을 세로로 읽어 나간다. 위의 그림 1의 다섯 번째 자리를 보면 두 번째 줄의 다섯 번째 자리의 글자는 없다. 이런 경우처럼 세로로 읽을 때 해당 자리의 글자가 없으면, 읽지 않고 그 다음 글자를 계속 읽는다. 그림 1의 다섯 번째 자리를 세로로 읽으면 D1gk로 읽는다. 
그림 1에서 영석이가 세로로 읽은 순서대로 글자들을 공백 없이 출력하면 다음과 같다:
Aa0aPAf985Bz1EhCz2W3D1gkD6x
칠판에 붙여진 단어들이 주어질 때, 영석이가 세로로 읽은 순서대로 글자들을 출력하는 프로그램을 작성하시오.

 

문제 해석

이문제는 빈 이차원 배열을 만들고 행과 열을 개행 없이 역으로 출력 하는 방식으로 풀어야 한다.

 

C++

#include <iostream>
using namespace std;

int main(){
    char arr[5][15] = {0,};
    for (int i =0; i<5; i++){
        cin >> arr[i];
    }
    for(int j = 0; j< 15; j++){
        for (int k = 0; k<5; k++) {
            if (arr[k][j] != 0) {
                cout << arr[k][j];
            }
        }
    }
}

 

코드해석

2차원 배열 arr 는 arr[5][15] = {0,  } 로 초기화 할경우 모두 0으로 초기화 된다.

여기서는 char 로 초기화 해줬으므로 0의 ASCII code 는 “NULL “ 이다.

입력한 값을 개행 없이 행과 열을 반대로 출력 하여 나열 한다.

'Algorithm > Beakjoon' 카테고리의 다른 글

[백준] 2745 진법 변환 (C++)  (0) 2023.05.15
[백준] 2563_색종이 (C++)  (0) 2023.05.14
[백준] 2908 (python)  (0) 2022.11.09
[백준] 1152 (python)  (0) 2022.10.24
[백준] 1157 (python)  (0) 2022.10.23

댓글