티스토리 뷰

PS

프로그래머스. 카펫

tose33 2021. 7. 28. 15:21

https://programmers.co.kr/learn/courses/30/lessons/42842

 

코딩테스트 연습 - 카펫

Leo는 카펫을 사러 갔다가 아래 그림과 같이 중앙에는 노란색으로 칠해져 있고 테두리 1줄은 갈색으로 칠해져 있는 격자 모양 카펫을 봤습니다. Leo는 집으로 돌아와서 아까 본 카펫의 노란색과

programmers.co.kr

 

 

백준 2858. 기숙사 바닥 이랑 완전 같은 문제이다.

https://tose33.tistory.com/210

 

백준 2858. 기숙사 바닥

https://www.acmicpc.net/problem/2858 2858번: 기숙사 바닥 첫째 줄에 상근이네 방의 크기 L과 W을 공백으로 구분하여 출력한다. 만약, 두 수가 다르다면, 큰 수가 L이 되고 작은 수가 W이 된다. 항상 정답이

tose33.tistory.com

 

근데 백준에서 이거 브론즈 문제였던것 같은데

프로그래머스에서 레벨2문제로 책정되어 있었다.

바로 전에 푼 소수찾기 문제도 레벨2였는데 난이도 차가 좀 있는것 같은데..

 

#include <vector>
#include <iostream>
using namespace std;

vector<int> solution(int brown, int yellow) {
    vector<int> answer;

    // 세로길이가 작은 경우부터 시작하고, 맞는 조건을 찾으면 바로 탐색을 중지하기 때문에
    // 답은 가로 길이가 세로길이와 같거나 세로길이 보다 긴 경우가됨
    for(int i = 3; i < brown; i++)
    {
        // 세로를 이루는 갈색격자의 총 갯수
        int height_total = i * 2;
        // 가로를 이루는 갈색격자의 총 갯수
        int width_total = brown - height_total + 4;

        // 카펫의 넓이
        int length = height_total/2 * width_total/2;

        // 카펫의 넓이와 갈색격자+노란격자 가 같으면 가능한 경우
        if(length == brown + yellow)
        {
            //cout << width_total/2 << ' ' << height_total/2 << endl;
            answer.push_back(width_total/2);
            answer.push_back(height_total/2);
            break;
        }

    }

    return answer;
}
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/04   »
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30
글 보관함