필기시험 개념 공부 | Code Kata [크기가 작은 부분문자열, 최소직사각형] | TIL 23th | 캠프 17일 차 | 05/14/2026 (Thur)

2026. 5. 14. 23:20·TIL

Agenda: 필기시험 개념 공부 | Code Kata [크기가 작은 부분문자열, 최소직사각형]


크기가 작은 부분문자열

  • 043. 크기가 작은 부분문자열 | Solved Date: 2026-05-14-Thur | Problem Link

문제 설명

숫자로 이루어진 문자열 t와 p가 주어질 때, t에서 p와 길이가 같은 부분문자열 중에서, 이 부분문자열이 나타내는 수가 p가 나타내는 수보다 작거나 같은 것이 나오는 횟수를 return하는 함수 solution을 완성하세요.

예를 들어, t="3141592"이고 p="271" 인 경우, t의 길이가 3인 부분 문자열은 314, 141, 415, 159, 592입니다. 이 문자열이 나타내는 수 중 271보다 작거나 같은 수는 141, 159 2개 입니다.


제한사항

  • 1 ≤ p의 길이 ≤ 18
  • p의 길이 ≤ t의 길이 ≤ 10,000
  • t와 p는 숫자로만 이루어진 문자열이며, 0으로 시작하지 않습니다.

입출력 예

"3141592" "271" 2
"500220839878" "7" 8
"10203" "15" 3

t p result


입출력 예 설명

입출력 예 #1

본문과 같습니다.

입출력 예 #2

p의 길이가 1이므로 t의 부분문자열은 "5", "0", 0", "2", "2", "0", "8", "3", "9", "8", "7", "8"이며 이중 7보다 작거나 같은 숫자는 "5", "0", "0", "2", "2", "0", "3", "7" 이렇게 8개가 있습니다.

입출력 예 #3

p의 길이가 2이므로 t의 부분문자열은 "10", "02", "20", "03"이며, 이중 15보다 작거나 같은 숫자는 "10", "02", "03" 이렇게 3개입니다. "02"와 "03"은 각각 2, 3에 해당한다는 점에 주의하세요


기본 코드

#include <string>
#include <vector>

using namespace std;

int solution(string t, string p) {
    int answer = 0;
    return answer;
}

힌트

  • long long
  • .length()
  • stoll()
  • substr()

문제 풀이 과정

문제 나누기

  • t 의 문자열 길이
  • p 의 문자열 길이
    • p 의 문자열 길이로 t의 문자열 쪼개기
  • t가 "123456789" 이고 p가 "123" 이면
  • t를 "123", "456", "789" 로 쪼개기
  • p 의 값과 쪼개진 t 의 값 비교 해서, p 가 더 크거나 같은 수의 갯 수 리턴.

문제 해석


정답 소스 코드

#include <string>
#include <vector>

using namespace std;

int solution(string t, string p) {
    int answer = 0;

    int t_lengnth = t.length();
    int p_length = p.length();

    int range = t_lengnth - p_length;

    long long p_val = stoll(p);

    for (int i = 0; i <= range; ++i)
    {
        string sub = t.substr(i, p_length);

        if (stoll(sub) <= p_val)
        {
            answer++;
        }
    }

    return answer;
}

Comments:

  • string substr(size_t pos = 0, size_t len = npos) const;
    • extracts a portion of a string and returns it as a new string object
    • pos: The starting index of the substring (0-indexed). Defaults to 0.
    • len: The number of characters to include. Defaults to npos (which means "until the end of the string").
  • stoll (string to long long)
  • int 사용시 에러 발생 out_of_range.
  • 문제에서 p 는 18 자리까지도 가능 (int 는 (2,147,483,647) (approx. (2 X 10^9)), 즉 10의 자리가 최대
  • 이 문제도 추후 다시 물어보다
  • 문자열 관련 문제들도 쓸일이 없다보니 계속 잘 안풀린다.

최소직사각형

  • 044. 최소직사각형 | Solved Date: 2026-05-14-Thur | Problem Link

문제 설명

명함 지갑을 만드는 회사에서 지갑의 크기를 정하려고 합니다. 다양한 모양과 크기의 명함들을 모두 수납할 수 있으면서, 작아서 들고 다니기 편한 지갑을 만들어야 합니다. 이러한 요건을 만족하는 지갑을 만들기 위해 디자인팀은 모든 명함의 가로 길이와 세로 길이를 조사했습니다.

아래 표는 4가지 명함의 가로 길이와 세로 길이를 나타냅니다.

1 60 50
2 30 70
3 60 30
4 80 40

명함 번호 가로 길이 세로 길이

가장 긴 가로 길이와 세로 길이가 각각 80, 70이기 때문에 80(가로) x 70(세로) 크기의 지갑을 만들면 모든 명함들을 수납할 수 있습니다. 하지만 2번 명함을 가로로 눕혀 수납한다면 80(가로) x 50(세로) 크기의 지갑으로 모든 명함들을 수납할 수 있습니다. 이때의 지갑 크기는 4000(=80 x 50)입니다.

모든 명함의 가로 길이와 세로 길이를 나타내는 2차원 배열 sizes가 매개변수로 주어집니다. 모든 명함을 수납할 수 있는 가장 작은 지갑을 만들 때, 지갑의 크기를 return 하도록 solution 함수를 완성해주세요.


제한사항

  • sizes의 길이는 1 이상 10,000 이하입니다.
    • sizes의 원소는 [w, h] 형식입니다.
    • w는 명함의 가로 길이를 나타냅니다.
    • h는 명함의 세로 길이를 나타냅니다.
    • w와 h는 1 이상 1,000 이하인 자연수입니다.

입출력 예

[[60, 50], [30, 70], [60, 30], [80, 40]] 4000
[[10, 7], [12, 3], [8, 15], [14, 7], [5, 15]] 120
[[14, 4], [19, 6], [6, 16], [18, 7], [7, 11]] 133

sizes result


입출력 예 설명

입출력 예 #1

문제 예시와 같습니다.

입출력 예 #2

명함들을 적절히 회전시켜 겹쳤을 때, 3번째 명함(가로: 8, 세로: 15)이 다른 모든 명함보다 크기가 큽니다. 따라서 지갑의 크기는 3번째 명함의 크기와 같으며, 120(=8 x 15)을 return 합니다.

입출력 예 #3

명함들을 적절히 회전시켜 겹쳤을 때, 모든 명함을 포함하는 가장 작은 지갑의 크기는 133(=19 x 7)입니다.


기본 코드

#include <string>
#include <vector>

using namespace std;

int solution(vector<vector<int>> sizes) {
    int answer = 0;
    return answer;
}

힌트

  • min
  • max

문제 풀이 과정

문제 나누기

  • 우선 배열 안의 값들 중 (원소) 가장 큰 숫자를 찾고 (highest_num)
  • 각 원소 [W, H] 중에서 highest_num 제외하고 그 다음으로 큰 수 찾기.
    • !!! 전체 중에서 두번째로 큰것을 찾는게 아닌 그 배열의 [W, H] 중에서 highest_num 제외하고 다음 큰 수를 찾는거.

문제 해석


정답 소스 코드

#include <string>
#include <vector>

#include <algorithm>
using namespace std;

int solution(vector<vector<int>> sizes) {
    int answer = 0;

    int max_val = 0;
    int secondHigh = 0;

    for (int i = 0; i < sizes.size(); i++)
    {
        for (int j = 0; j < sizes[i].size(); j++)
        {
            max_val = max(max_val, sizes[i][j]);
        }
    }

    for (int i = 0; i < sizes.size(); i++)
    {

        int min_val = min(sizes[i][0], sizes[i][1]);
        secondHigh = max(secondHigh, min_val);
    }

    return answer = max_val * secondHigh;
}

Comments:

  • 대입 해보려면: vector < vector> sizes{ {60, 50}, {30, 70}, {60, 30}, {80, 40} };

정석 답안지:

#include <string>
#include <vector>
#include <algorithm>

using namespace std;

int solution(vector<vector<int>> sizes) {
    int max_w = 0;
    int max_h = 0;

    for (const auto& size : sizes) {
        // 명함의 가로, 세로 중 긴 쪽을 max_w에, 짧은 쪽을 max_h에 갱신
        max_w = max(max_w, max(size[0], size[1]));
        max_h = max(max_h, min(size[0], size[1]));
    }

    // 가장 긴 가로와 가장 긴 세로를 곱한 값이 최소 지갑 크기
    return max_w * max_h;
}
  • const vector& row 에서 왜 const 랑 & 이 들어가는 이유
    • const vector& row에서 const와 &를 사용하는 이유는 메모리 낭비를 막고(성능 최적화), 데이터를 안전하게 보호하기 위해
    1. & (참조자)를 쓰는 이유: 성능 최적화
    • 복사 방지: &가 없으면 루프를 돌 때마다 각 행(vector<int>)의 전체 데이터가 새로운 메모리 공간에 통째로 복사됩니다.
    • 성능 향상: &를 붙이면 데이터 복사 없이 원래 메모리에 있는 데이터의 주소(참조)만 가져오므로 대용량 데이터도 순식간에 처리합니다.
    1. const를 쓰는 이유: 데이터 보호
    • 실수 방지: 참조(&)를 사용하면 루프 내부에서 row[0] = 10;처럼 값을 바꿨을 때 원본 sizes 배열의 값도 함께 바뀌어 버립니다.
    • 읽기 전용: 앞에 const를 붙여줌으로써 루프 안에서 원본 데이터가 **절대 수정되지 않도록 안전하게 잠금(Lock)**을 거는 역할을 합니다.
  • 세 줄 요약
    • &가 없으면 데이터 복사 때문에 느려집니다.
    • const가 없으면 실수로 원본 데이터가 바뀔 수 있습니다.
    • 따라서 값을 읽기만 할 때는 const & 조합이 C++의 **가장 표준적인 모범 사례(Best Practice)**입니다
저작자표시 동일조건 (새창열림)
'TIL' 카테고리의 다른 글
  • 코드 카타 (Code Kata): 기사단원의 무기, 덧칠하기 | TIL 31th | 06/03/2026 (Wed)
  • 코드 카타 (Code Kata) : 명예의 전당, 2016 | 달력 문제 정리 | TIL 28th | 05/31/2026 (Sun)
  • 필기시험 B part 2 & 3 | Code Kata: 삼총사 | TIL 22th | 캠프 16일 차 | 05/13/2026 (Wed)
  • 2025 게임 프로그래밍 전문가 국가기술 자격검정 필기시험 B, Part1 풀이 & 해석 | Code Kata: 이상한 문자 만들기 | TIL 21th | 캠프 15일 차 | 05/12/2026 (Tue)
DevCol
DevCol
DevCol (Development Collaboration). 함께 개발 & 공부 & IT 정보 나눔장소
  • DevCol
    DevCol (Development Collaboration)
    DevCol
  • 블로그 메뉴

    • Unreal Engine
    • TIL
    • 게임국가기술자격검정 게임프로그래밍전문가 [한국콘텐츠진흥원]
    • 분류 전체보기 (73) N
      • Unreal Engine (31) N
        • Project (2) N
        • Dev Log (0)
        • Debugging (2) N
        • Blueprint (1)
        • UE 기초 (25) N
        • UE 심화 (0)
        • TA (1) N
      • Programming Language (0)
        • C++ (0)
        • C# (0)
      • Unity Engine (0)
      • 자격증 (3)
        • 게임국가기술자격검정 [한국콘텐츠진흥원] (3)
      • Coding Test | 코딩테스트 (0)
        • 프로그래머스 기초 (0)
        • 프로그래머스 입문 (0)
      • TIL (38) N
        • Boot Camp (32) N
      • Git & Github (1)
  • 링크

    • Youtube
    • GitHub
    • itch.io
    • Blog (En)
  • 공지사항

  • 인기 글

  • 태그

    기초
    UE
    C++
    Boot Camp
    Game Dev
    UE5
    Devlog
    게임 개발
    Code Kata
    c
    코드 카타
    게임개발
    til
    코드카타
    Unreal engine
    프로그래밍
    Programming
    cpp
    내일배움캠프
    언리얼 엔진
  • 최근 글

  • GitHub Youtube itch
  • hELLO · Designed By 정상우.v4.10.6
  • DevCol
    필기시험 개념 공부 | Code Kata [크기가 작은 부분문자열, 최소직사각형] | TIL 23th | 캠프 17일 차 | 05/14/2026 (Thur)
    상단으로

    티스토리툴바