inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

5-Z

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

해결된 질문

128

한유태

작성한 질문수 79

0

안녕하세요 선생님 🙂

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

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

 

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

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

 

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

http://boj.kr/e6357bc26b214a5093bee0fc0e077486

c++ 코딩-테스트

답변 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

코딩 살구 클럽 로그인 문제

0

31

2

2-J 채점관련 질문

0

28

3

코딩 살구 클럽 Python 지원 가능 여부

0

48

1

살구클럽 아이디 없음 문제

0

58

1

1-O 코딩살구클럽 채점관련 질문

0

45

2

히든 테스트 케이스가 사라졌습니다

0

42

1

채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요

1

54

2

살구 클럽 채점 관련 문의(테스트 케이스)

0

52

2

1-H 문제 채점하기 오류

0

47

3

코딩살구클럽 2주차 2-L 문제 채점하기 오류

0

42

2

살구 클럽 채점 관련 문의

0

55

2

코딩 살구 클럽 실전 세션

0

48

2

코딩살구클럽 채점 관련 질문

0

42

2

코딩살구클럽 컴파일에러

0

74

2

5-B

0

48

2

4 - A

0

53

2

코딩살구클럽 입장이 안됩니다

0

124

2

4-F 경우의 수 질문입니다.

0

53

2

코딩살구클럽 가입이 안됩니다.

0

119

2

살구 클럽에 대한 질문있습ㄴ디ㅏ

0

78

1

교안 158페이지 문의드립니다

0

53

2

코딩살구클럽 관련 건의사항

0

162

1

코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다

0

54

1

진행 방법 질문드립니다!

0

102

2