인프런 커뮤니티 질문&답변

한유태님의 프로필 이미지
한유태

작성한 질문수

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

5-Z

5-Z 변형 질문 드립니다 :)

해결된 질문

작성

·

38

0

안녕하세요 선생님 🙂

최근들어 질문을 너무 많이 하는 것 같아서 정말 죄송합니다 ㅠㅠ

그만큼 절실하다는 것으로 받아들여주시면 정말 감사하겠습니다 🙂

 

아래는 배열이 아닌 vector<pair<int, int>> 자료형으로 문제를 풀이하였습니다.

하지만, 그동안 배열과 vector<pair<int, int>> 자료형을 많이 사용해서 그런지 vector<vector<int>> 자료형으로 변환을 해보려고 하고 있으나 풀이가 잘 안되더라구요 ㅠㅠ

 

코테를 많이 보진 않았지만 그동안 보았던 코테는 함수를 딸랑 하나놓고 함수를 채워나가는 형식이었는데요, 제가 기억하기로 vector<pair<int, int>>보다는 파라미터로 vector<vector<int>> 자료형이 많았던 것으로 기억합니다. 계속해서 연습하고는 있지만 잘 안되어서 도움 요청 드립니다 :)

http://boj.kr/e6357bc26b214a5093bee0fc0e077486

답변 3

1

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요 유태님ㅎㅎ

질문 많이 해주셔도 됩니다. 다만 코테 합격하셔야 해요!! ㅎㅎ

#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

int N;
int result;

int main()
{
    ios::sync_with_stdio(false);
    cin.tie(NULL); cout.tie(NULL);

    cin >> N;
    vector<vector<int>> vec(N, vector<int>(2));
     
    for (int i = 0; i < N; i++)
    {
        cin >> vec[i][0] >> vec[i][1];
    }
 
    sort(vec.begin(), vec.end());

    int Start = vec[0][0];
    int End = vec[0][1];

    for (int i = 1; i < N; i++)
    { 
        if (End >= vec[i][0] && End <= vec[i][1])
        {
            End = vec[i][1];
        } 
        else if (End < vec[i][0])
        {
            result += (End - Start);
            Start = vec[i][0];
            End = vec[i][1];
        }
    }
 
    result += (End - Start);

    cout << result << '\n';

    return 0;
}

이렇게 하시면 됩니다. 😃

1

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요 유태님ㅎㅎ

질문 많이 해주셔도 됩니다. 다만 코테 합격하셔야 해요!! ㅎㅎ

#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

int N;
int result;

int main()
{
    ios::sync_with_stdio(false);
    cin.tie(NULL); cout.tie(NULL);

    cin >> N;
    vector<vector<int>> vec(N, vector<int>(2));
     
    for (int i = 0; i < N; i++)
    {
        cin >> vec[i][0] >> vec[i][1];
    }
 
    sort(vec.begin(), vec.end());

    int Start = vec[0][0];
    int End = vec[0][1];

    for (int i = 1; i < N; i++)
    { 
        if (End >= vec[i][0] && End <= vec[i][1])
        {
            End = vec[i][1];
        } 
        else if (End < vec[i][0])
        {
            result += (End - Start);
            Start = vec[i][0];
            End = vec[i][1];
        }
    }
 
    result += (End - Start);

    cout << result << '\n';

    return 0;
}

이렇게 하시면 됩니다. 😃

0

한유태님의 프로필 이미지
한유태
질문자

혹시 이렇게 풀면 될까요?

http://boj.kr/626e8cd0561c47c38e81d9bd6c0b8f19

한유태님의 프로필 이미지
한유태

작성한 질문수

질문하기