출처 : 반크_세계유산 창덕궁
문제]
아직 글을 모르는 영석이가 벽에 걸린 칠판에 자석이 붙어있는 글자들을 붙이는 장난감을 가지고 놀고 있다.
이 장난감에 있는 글자들은 영어 대문자 ‘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
<그림 1>
한 줄의 단어는 글자들을 빈칸 없이 연속으로 나열해서 최대 15개의 글자들로 이루어진다. 또한 만들어진 다섯 개의 단어들의 글자 개수는 서로 다를 수 있다.
심심해진 영석이는 칠판에 만들어진 다섯 개의 단어를 세로로 읽으려 한다. 세로로 읽을 때, 각 단어의 첫 번째 글자들을 위에서 아래로 세로로 읽는다. 다음에 두 번째 글자들을 세로로 읽는다. 이런 식으로 왼쪽에서 오른쪽으로 한 자리씩 이동 하면서 동일한 자리의 글자들을 세로로 읽어 나간다. 위의 그림 1의 다섯 번째 자리를 보면 두 번째 줄의 다섯 번째 자리의 글자는 없다. 이런 경우처럼 세로로 읽을 때 해당 자리의 글자가 없으면, 읽지 않고 그 다음 글자를 계속 읽는다. 그림 1의 다섯 번째 자리를 세로로 읽으면 D1gk로 읽는다.
그림 1에서 영석이가 세로로 읽은 순서대로 글자들을 공백 없이 출력하면 다음과 같다.
Aa0aPAf985Bz1EhCz2W3D1gkD6x
칠판에 붙여진 단어들이 주어질 때, 영석이가 세로로 읽은 순서대로 글자들을 출력하는 프로그램을 작성하시오.
입력
총 다섯줄의 입력이 주어진다. 각 줄에는 최소 1개, 최대 15개의 글자들이 빈칸 없이 연속으로 주어진다. 주어지는 글자는 영어 대문자 ‘A’부터 ‘Z’, 영어 소문자 ‘a’부터 ‘z’, 숫자 ‘0’부터 ‘9’ 중 하나이다. 각 줄의 시작과 마지막에 빈칸은 없다.
출력
영석이가 세로로 읽은 순서대로 글자들을 출력한다. 이때, 글자들을 공백 없이 연속해서 출력한다.
예제 입력 1
ABCDE
abcde
01234
FGHIJ
fghij
예제 출력 1
Aa0FfBb1GgCc2HhDd3IiEe4Jj
예제 입력 2
AABCDD
afzz
09121
a8EWg6
P5h3kx
예제 출력 2
Aa0aPAf985Bz1EhCz2W3D1gkD6x
출처 : 백준_10798
참고풀이]
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
int main()
{
char S[5][63]={'\0'};//5개의 문자열이 입력될 문자열 변수
int r, c, n;//인덱스 또는 반복변수
int N;//5개의 문자열의 전체 문자개수 변수
int Max;//한개 문자열의 길이가 제일 긴 문자개수 변수
//5개의 문자열을 읽어온다.
for(r=0;r<5;r++)
{
scanf("%s",&S[r]);
for(c=0;c<strlen(S[r]);c++)
{
if((S[r][c]>='a' && S[r][c]<='z') ||
(S[r][c]>='A' && S[r][c]<='Z') ||
(S[r][c]>='0' && S[r][c]<='9'));
else
{
printf("a~z, A~Z, 0~9 사이의 문자가 아닙니다.\n");
printf("작업을 종료합니다.\n");
return 0;
}
}
}
//입력된 문자열을 세로로 읽어 저장할 문자열 변수를 만든다.
//입력된 문자열 중 제일 긴 문자열의 길이를 구한다.
N=0;
Max=strlen(S[0]);
for(r=0;r<5;r++)
{
N+=strlen(S[r]);
if(Max<strlen(S[r])) Max=strlen(S[r]);
}
//5개의 문자열의 길이를 합한 길이와 문자열의 끝을 알리는 '\0'가 저장될
//동적변수를 설정한다.
char *Str=(char *)malloc(sizeof(char)*(N+1));
//5개의 문자열을 세로로 읽어 저장한다.
for(n=0,c=0;c<Max;c++)
for(r=0;r<5;r++)
if(S[r][c] != '\0') Str[n++]=S[r][c];
Str[n]='\0';
//결과출력
printf("%s",Str);
return 0;
}
참고풀이 결과]
대한민국의 아름다운 영토, 독도의 여름
'프로그램 > C언어 1000제' 카테고리의 다른 글
C언어 151제] 2013년 한국정보올림피아드 지역본선 초등부 2번 덩치 (0) | 2024.07.02 |
---|---|
C언어 150제] 2014년 한국정보올림피아드 지역본선 초등부 2번 자리배정 (0) | 2024.07.02 |
C언어 148제] 2022년 연세대학교 미래캠퍼스 슬기로운 코딩생활 B번 커트라인 (0) | 2024.06.17 |
C언어 147제] 2005년 한국정보올림피아드 지역본선 초등부 1번 대표값2 (0) | 2024.06.17 |
C언어 146제] 2006년 한국정보올림피아드 지역본선 초등부 1번 홀수 (0) | 2024.06.17 |
댓글