[취업] Kakao 코딩 테스트 문제[2]
- 공유 링크 만들기
- X
- 이메일
- 기타 앱
2번째 문제를 한번 풀어보았습니다...!
점수판 계산 문제이며, 대게 파싱에 대한 문제인것 같습니다.
다음은 문제입니다.
2. 다트 게임 (난이도: 하)
카카오톡 게임별의 하반기 신규 서비스로 다트 게임을 출시하기로 했다. 다트 게임은 다트판에 다트를 세 차례 던져 그 점수의 합계로 실력을 겨루는 게임으로, 모두가 간단히 즐길 수 있다.
갓 입사한 무지는 코딩 실력을 인정받아 게임의 핵심 부분인 점수 계산 로직을 맡게 되었다. 다트 게임의 점수 계산 로직은 아래와 같다.
다트 게임은 총 3번의 기회로 구성된다.
- 각 기회마다 얻을 수 있는 점수는 0점에서 10점까지이다.
- 점수와 함께 Single(S), Double(D), Triple(T) 영역이 존재하고 각 영역 당첨 시 점수에서 1제곱, 2제곱, 3제곱 (점수^1 , 점수^2 , 점수^3 )으로 계산된다.
- 옵션으로 스타상(*) , 아차상( # )이 존재하며 스타상( * ) 당첨 시 해당 점수와 바로 전에 얻은 점수를 각 2배로 만든다. 아차상(#) 당첨 시 해당 점수는 마이너스된다.
- 스타상( * )은 첫 번째 기회에서도 나올 수 있다. 이 경우 첫 번째 스타상( * )의 점수만 2배가 된다. (예제 4번 참고)
- 스타상( * )의 효과는 다른 스타상( * )의 효과와 중첩될 수 있다. 이 경우 중첩된 스타상(*) 점수는 4배가 된다. (예제 4번 참고)
- 스타상( * )의 효과는 아차상( # )의 효과와 중첩될 수 있다. 이 경우 중첩된 아차상(#)의 점수는 -2배가 된다. (예제 5번 참고)
- Single(S), Double(D), Triple(T)은 점수마다 하나씩 존재한다.
- 스타상( * ), 아차상( # )은 점수마다 둘 중 하나만 존재할 수 있으며, 존재하지 않을 수도 있다.
- 0 ~ 10의 정수와 문자 S, D, T, *, #로 구성된 문자열이 입력될 시 총점수를 반환하는 함수를 작성하라.
입력 형식
“점수|보너스|[옵션]”으로 이루어진 문자열 3세트.
예) 1S2D*3T
점수는 0에서 10 사이의 정수이다.
보너스는 S(1제곱), D(2제곱), T(3제곱) 중 하나이다.
옵션은 *(pre점수 + ) 이나 #(해당점수 - ) 중 하나이며, 없을 수도 있다.
출력 형식
3번의 기회에서 얻은 점수 합계에 해당하는 정수값을 출력한다.
예) 37
이 문제는 문자열들에 대해
해당 입력패턴을 분석하여 값을 처리하면 되게됩니다.
문제 중에 신경써야 될 부분이 일단,
0 ~ 10의 정수인데, c++일 경우, 최소 두번을 읽도록 검사를 해야하죠..
1. 숫자 Read
2. 문자열 처리 ( S , D , T )
3. 특수 이벤트 처리 ( *, # )
4. 1 ~ 3 반복
보통 switch로 처리 할 수 있어 보이는데,
저의 경우는 함수 콜백으로 처리하였습니다.
로직을 설명하자면...
1. 함수 콜백 등록
2. ptr로 문자열에 대해 read
3. 해당 키워드의 함수 CallBack이 없으면 숫자
3-1. 숫자에 해당하면, 숫자 버퍼에 값 복사
4. 함수 콜백에 해당하는 값, 숫자 버퍼 저장된 값을 list에 push_back
4-1. 각 function 수행
5. 2 ~ 4 반복
소스코드입니다.
#include <stdio.h> #include <string.h> #include <stdlib.h> #include <iostream> #include <list> #include <map> #include <math.h> #define LOG printf using namespace std; typedef void (*CallBackFunc)(list<int>&); map<char, CallBackFunc> funcMap; void SingleScore(list<int<& scoreList) { return ; } void DoubleScore(list<int>& scoreList) { if ( scoreList.size() <= 0 ) { return ; } int val = scoreList.back(); scoreList.pop_back(); int result = pow(val, 2); scoreList.push_back(result); } void TreepleScore(list<int>& scoreList) { if ( scoreList.size() <= 0 ) { return ; } int val = scoreList.back(); scoreList.pop_back(); int result = pow(val, 3); scoreList.push_back(result); } void StarScore(list<int>& scoreList) { int starVal[2] = { 0, }; int idx; for ( idx = 0; idx < 2 ; idx++ ) { if ( scoreList.size() <= 0 ) { break; } starVal[idx] = scoreList.back() * 2; scoreList.pop_back(); } while( idx > 0 ) { idx--; scoreList.push_back(starVal[idx]); } } void SharpScore(list<int>& scoreList) { if ( scoreList.size() <= 0 ) { return ; } int val = scoreList.back() * (-1); scoreList.pop_back(); scoreList.push_back(val); } char score[][20] = { {"1S2D*3T"}, {"1D2S#10S"}, {"1D2S0T"}, {"1S*2T*3S"}, {"1D#2S*3S"}, {"1T2D3D#"}, {"1D2S3T*"}, }; int printList(list<int>& scoreList) { int score = 0; list<int>::iterator it; int idx = 0; for ( it = scoreList.begin(); it != scoreList.end(); it++ ) { LOG("|idx[%d] : %d |",idx, *it); score += *it; idx ++; } return score; } int main(void) { funcMap.insert( pair<char, CallBackFunc>('S', SingleScore) ); funcMap.insert( pair<char, CallBackFunc>('D', DoubleScore) ); funcMap.insert( pair<char, CallBackFunc>('T', TreepleScore) ); funcMap.insert( pair<char, CallBackFunc>('*', StarScore) ); funcMap.insert( pair<char, CallBackFunc>('#', SharpScore) ); list<int> scoreList; int size = sizeof(score) / sizeof(score[0]); for ( int i = 0; i < size; i++ ) { const char* ptr = score[i]; char strNumber[3]; memset(strNumber, '\0', sizeof(char) * 3); char* numberPtr = strNumber; while( *ptr ) { void (*func)(list<int>&) = NULL; func = funcMap.find(*ptr)->second; if ( func ) { if ( strlen ( strNumber ) > 0 ) { scoreList.push_back(atoi(strNumber)); } func(scoreList); memset(strNumber, '\0', sizeof(char) * 3); numberPtr = strNumber; } else { *numberPtr = *ptr; numberPtr++; } ptr++; } LOG(" = score[%d] : %d\n", i, printList(scoreList)); scoreList.clear(); } return 0; }
추가로 읽으면 좋을 것
- 공유 링크 만들기
- X
- 이메일
- 기타 앱
이 블로그의 인기 게시물
윤석열 계엄령 선포! 방산주 대폭발? 관련주 투자 전략 완벽 분석
## 1. 배경 2024년 12월 3일, 윤석열 대통령이 국가 비상사태를 이유로 계엄령을 선포하였습니다. 계엄령은 전시나 사변 등 국가의 안녕과 공공질서가 심각하게 위협받을 때 대통령이 군사적 권한을 통해 이를 방어하고 유지하기 위해 발효하는 특별한 조치입니다. 이러한 조치는 국내 정치·경제 전반에 큰 영향을 미치며, 특히 주식시장에서는 관련 기업들의 주가 변동이 예상됩니다. 24.12.03 오전 5시 계엄 해제로 아래 관련주 추천 - [윤석열 계엄령 해제! 이재명 관련주 급등? 투자자 필독 전략](https://warguss.blogspot.com/2024/12/yoon-martial-law-lift-lee-jaemyung-stocks.html) --- ## 2. 기업 및 관련주 ### 2-1 식품 관련주 - 계엄령이 선포되면 사회적 불안정성이 증가할 수 있으며, 이에 따라 생필품 및 음식 관련 주식이 단기적으로 강세를 보일 가능성이 있습니다. #### 1. CJ제일제당 (KOSPI: 097950) [시가총액: 약 10조 원] - **주요 산업**: 식품 및 생필품 제조 - **관련주 근거**: 국가적 위기 상황에서 식료품 수요가 증가하며, 즉석밥, 가공식품 등의 판매가 확대될 가능성이 있습니다. - **주가정보**: [네이버 차트](https://finance.naver.com/item/main.nhn?code=097950) #### 2. 오뚜기 (KOSPI: 007310) [시가총액: 약 3조 원] - **주요 산업**: 식품 제조 및 유통 - **관련주 근거**: 라면, 즉석식품 등 비축 가능한 식품 수요가 증가하며, 매출 상승이 기대됩니다. - **주가정보**: [네이버 차트](https://finance.naver.com/item/main.nhn?code=007310) #### 3. 대상 (KOSPI: 001680) [시가총액: 약 2조 원] - **주요 산업**: 식품 제조 및 발효제품 - **관련주 근거**: 계엄...
대통령 퇴진운동 관련주: 방송·통신·촛불수혜주 완벽 분석
--- ## 1. 배경 2024년 12월 3일, 윤석열 대통령이 비상계엄령을 선포했으나, 짧은 시간 내에 이를 해제하면서 정치적 긴장감이 커졌습니다. 이에 따라 대규모 촛불시위와 같은 사회적 움직임이 예상되며, 통신과 관련된 기업 및 촛불 제조와 연관된 산업에 관심이 모이고 있습니다. --- ## 2. 기업 및 관련주 대규모 시위 및 관련 활동으로 인해 통신, 미디어, 그리고 촛불 제조와 관련된 기업들이 단기적인 수혜를 볼 것으로 예상됩니다. ### 2-1. 통신 관련주 #### 1. **KT (030200) [약 12조 원]** - **주요 산업:** 통신 - **관련주 근거:** 시위 생중계 및 대규모 통신 트래픽 증가로 매출 증대 가능성 - **주가정보:** [네이버 차트](https://finance.naver.com/item/main.nhn?code=030200) #### 2. **SK텔레콤 (017670) [약 12조 원]** - **주요 산업:** 통신 - **관련주 근거:** 대규모 데이터 사용 증가로 인한 수익 상승 - **주가정보:** [네이버 차트](https://finance.naver.com/item/main.nhn?code=017670) #### 3. **LG유플러스 (KOSPI, 032640) [약 4.9조 원]** - **주요 산업:** 통신 - **관련주 근거:** 촛불시위로 인한 데이터 및 음성 서비스 사용 증가 예상 - **주가정보:** [네이버 차트](https://finance.naver.com/item/main.nhn?code=032640) --- ### 2-2. 방송 관련주 #### 1. **SBS (034120) [약 2,924억 원]** - **주요 산업:** 방송 및 미디어 콘텐츠 제작 - **관련주 근거:** 시위 관련 특집 방송 및 실시간 보도에 따른 광고 수익 증가 - **주가정보:** [네이버 차트](https://finance.naver.com/item/main.nhn?code...
키움 OPEN API MFC 개발 (1)
* 키움 API 개발 - visual studio 2019 , MFC * Visual Studio Set - 새 프로젝트 만들기 / MFC 검색 - 다음 이후, MFC 설정에서 어플리케이션 종류 변경 (대화 상자 기반) * 기본 적용 Flow ( https://www.kiwoom.com/nkw.templateFrameSet.do?m=m1408000000 ) = 우선 생략하고, Step 2 설치 = Step 3 자료실/ KhOpenApiTest_2.71.zip 다운로드 * Step 2 설치 후, 설치 경로의 OpenAPI 디렉토리 찾기 1. 파일 찾기 2. KHOpenAPI.ocx 를 프로젝트 소스에 복사 * Step 3 자료실/다운로드 1. khOpenApiTest_2.71.zip 다운/압축 풀고, 2. KHOpenAPI.cpp/h KHOpenAPICtrl.cpp/h 프로젝트 소스에 복사 * 내부 소스에 다음추가 header에 class 생성 cpp에 다음 소스 추가 * 리소스 뷰 > IDD_TRADINGAPP_DIALOG 1. 확인 우클릭 > Active X 컨트롤 삽입 2. KHOpenAPI Control 적용 하면 위 화면처럼 적용 이후 실행 시 다음 화면 이후 매수/매도 적용
댓글
댓글 쓰기