inflearn logo
강의

講義

知識共有

10週間完成 C++ コーディングテスト | アルゴリズムコーディングテスト

5-Z

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

解決済みの質問

134

han9311200463

投稿した質問数 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

kundol

안녕하세요 유태님ㅎㅎ

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

#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

kundol

안녕하세요 유태님ㅎㅎ

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

#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

han9311200463

혹시 이렇게 풀면 될까요?

http://boj.kr/626e8cd0561c47c38e81d9bd6c0b8f19

비쥬얼 스튜디오로 해도 되나요?

0

15

2

코딩살구클럽 가입 문의

0

56

2

코딩 살구 클럽 컴파일 에러

0

31

2

추천 문제

0

32

2

코딩살구클럽 승인

0

42

2

코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의

0

36

2

문제를 고민하는 시간 관련

0

29

2

코딩살구클럽

0

45

2

코딩살구클럽 문의

0

48

2

코딩살구클럽 승인

0

42

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

37

2

3-F 채점 관련 질문

0

34

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

38

2

코딩살구클럽 승인

0

47

2

코딩살구클럽승인

0

39

3

코딩살구클럽 승인

0

59

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

46

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

59

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

코딩 살구 클럽 접속 및 사용방법 문의

0

69

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

68

2