/*

카카오 신입공채 1차 코딩테스트 문제1 비밀지도

 

문제설명

네오는 평소 프로도가 비상금을 숨겨놓는 장소를 알려줄 비밀지도를 손에 넣었다. 그런데 이 비밀지도는 숫자로 암호화되어 있어 위치를 확인하기 위해서는 암호를 해독해야 한다. 다행히 지도 암호를 해독할 방법을 적어놓은 메모도 함께 발견했다.

 

지도는 한 변의 길이가 n인 정사각형 배열 형태로, 각 칸은 “공백”(“ “) 또는 “벽”(“#”) 두 종류로 이루어져 있다.

전체 지도는 두 장의 지도를 겹쳐서 얻을 수 있다. 각각 “지도 1”과 “지도 2”라고 하자. 지도 1 또는 지도 2 중 어느 하나라도 벽인 부분은 전체 지도에서도 벽이다. 지도 1과 지도 2에서 모두 공백인 부분은 전체 지도에서도 공백이다.

“지도 1”과 “지도 2”는 각각 정수 배열로 암호화되어 있다.

암호화된 배열은 지도의 각 가로줄에서 벽 부분을 1, 공백 부분을 0으로 부호화했을 때 얻어지는 이진수에 해당하는 값의 배열이다.

 

이해이미지)

[0001]:# ###

[0002]:#    #

[0003]:#    #

[0004]: # ##

[0005]: #####

[0006]:##  #

[0001]: ## ##

[0002]:###

[0003]: #  ##

[0004]:  ###

[0005]:  ###

[0006]:  # #

[0001]:######

[0002]:###  #

[0003]:##  ##

[0004]: ####

[0005]: #####

[0006]:### #

 

 

 

[0001]:[# ### ][ ## ##][######]

[0002]:[#    #][###   ][###  #]

[0003]:[#    #][ #  ##][##  ##]

[0004]:[ # ## ][  ### ][ #### ]

[0005]:[ #####][  ### ][ #####]

[0006]:[##  # ][  # # ][### # ]

 

네오가 프로도의 비상금을 손에 넣을 수 있도록, 비밀지도의 암호를 해독하는 작업을 도와줄 프로그램을 작성하라.

 

입력형식

입력으로 지도의 한 변 크기 n 과 2개의 정수 배열 arr1, arr2가 들어온다.

arr1, arr2는 길이 n인 정수 배열로 주어진다.

정수 배열의 각 원소 x를 이진수로 변환했을 때의 길이는 n 이하이다. 즉, 0 ? x ? 2^n - 1을 만족한다.

 

출력형식

원래의 비밀지도를 해독하여 "#", 공백으로 구성된 문자열 배열로 출력하라.

 

문제해설

이 문제는 비트 연산Bitwise Operation을 묻는 문제입니다. 이미 문제 예시에 2진수로 처리하는 힌트가 포함되어 있고, 둘 중 하나가 1일 경우에 벽 #이 생기기 때문에 OR로 처리하면 간단히 풀 수 있습니다. 아주 쉬운 문제였던 만큼 if else로 풀이한 분들도 많이 발견되었는데요. 정답으로는 간주되지만 이 문제는 비트 연산을 잘 다룰 수 있는지를 묻고자 하는 의도였던 만큼 앞으로 이런 유형의 문제를 풀 때는 비트 연산을 꼭 기억하시기 바랍니다.

 

이 문제의 정답률은 81.78%입니다. 첫 번째 문제이고 가장 쉬운 문제였던 만큼 많은 분들이 잘 풀어주셨습니다.

*/

 

 

#include <stdio.h>

#include <string.h>

 

void ____set_decoration(int NN, char resultstr[6][100], int width[6], char idx)

{

int ii, height;

 

height=0;

for(ii=0; ii<NN; ii++)

{

resultstr[height][width[ii]] = idx;

width[ii]++;

height++;

}

}

 

int main(int argc, char *argv[])

{

    int NN=6;

int arr1[6] = {46, 33, 33 ,22, 31, 50};

    int arr2[6] = {27 ,56, 19, 14, 14, 10};

    int hexadecimal[16] = {0x0001,0x0002,0x0004,0x0008,0x0010,0x0020,0x0040,0x0080,

0x0100,0x0200,0x0400,0x0800,0x1000,0x2000,0x4000,0x8000};

int ii,kk;

int width[6];

int height=0;

char resultstr[6][100];

 

memset(resultstr,0x00,sizeof(resultstr));

memset(width,0x00,sizeof(width));

 

#if(1)

____set_decoration(NN,resultstr,width,'2');

 

height=0;

for(ii=0; ii<NN; ii++)

{

printf("[%.4d]:",ii+1);

for(kk=0; kk<NN; kk++)

{

if((hexadecimal[NN-1] >> kk) & arr1[ii])

{

printf("#");

 

resultstr[height][width[ii]] = '9';

width[ii]++;

}

else

{

printf(" ");

 

resultstr[height][width[ii]] = '1';

width[ii]++;

}

}

printf("\n");

height++;

}

#endif

 

    ____set_decoration(NN,resultstr,width,'3');

    ____set_decoration(NN,resultstr,width,'2');

 

#if(1)

 

height=0;

for(ii=0; ii<NN; ii++)

{

printf("[%.4d]:",ii+1);

for(kk=0; kk<NN; kk++)

{

if((hexadecimal[NN-1] >> kk) & arr2[ii])

{

printf("#");

 

resultstr[height][width[ii]] = '9';

width[ii]++;

}

else

{

printf(" ");

 

resultstr[height][width[ii]] = '1';

width[ii]++;

}

}

printf("\n");

height++;

}

#endif

 

    ____set_decoration(NN,resultstr,width,'3');

    ____set_decoration(NN,resultstr,width,'2');

 

    height=0;

for(ii=0; ii<NN; ii++)

{

printf("[%.4d]:",ii+1);

for(kk=0; kk<NN; kk++)

{

if((hexadecimal[NN-1] >> kk) & arr1[ii] || (hexadecimal[NN-1] >> kk) & arr2[ii])

{

printf("#");

 

resultstr[height][width[ii]] = '9';

width[ii]++;

}

else

{

printf(" ");

 

resultstr[height][width[ii]] = '1';

width[ii]++;

}

}

printf("\n");

height++;

}

 

    ____set_decoration(NN,resultstr,width,'3');

 

    printf("\n\n\n");

    for(kk=0; kk<NN; kk++)

{

printf("[%.4d]:",kk+1);

    for(ii=0; ii<100; ii++)

{

if(resultstr[kk][ii]=='9') printf("#");

else if(resultstr[kk][ii]=='1') printf(" ");

else if(resultstr[kk][ii]=='2') printf("[");

else if(resultstr[kk][ii]=='3') printf("]");

else if(resultstr[kk][ii]==0x00) break;

}

printf("\n");

}

return(0);

}

 

+ Recent posts