inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

8-Z

선생님 8-Z 질문있습니다

259

정선우

작성한 질문수 4

0

해당 문제 시간 복잡도에 대해 궁금해서 문의드립니다.

위의 그림처럼 n(꼭짓점 개수)=100,000이고 x와 평행한 선분이 n/2=50,000개 나올 때 , x=1에서 x=1,000,000까지 스위핑을 해야 하는 사례에서는 시간 복잡도가 5*10^9로 시간 초과가 날 거라 판단하고 다른 방법을 고민하고 풀었는데 스위핑 방식도 가능하네요. 스위핑 방식이 시간초과가 나지 않을 거라는 걸 어떻게 알 수 있나요?

 

항상 빠른 답변해주셔서 감사합니다.

C++ 코테 준비 같이 해요!

답변 1

0

큰돌

안녕하세요 선우님 ㅎㅎ

스위핑을 해야 하는 사례에서는 시간 복잡도가 5*10^9로 시간 초과가 날 거라 판단

>> 왜 이렇게 판단하셨나요?

 

감사합니다.

0

정선우

한번 스위핑에 x=1에서 x=1.000,000까지 이동하니깐 한번 이동에 10^5이고 x축과 평행한 선분이 5*10^4개 있으므로
(10^5) * (5*10^4) = 5*10^9으로 계산했고 1억을 넘는 수라 시간초과가 날 거라 생각했습니다

※ 수정 : 10^5이 아니라 10^6이네요. 5*10^10이 정확한 값입니다.

0

큰돌

음.. 좌표이동은 O(1)의 시간복잡도를 가집니다.시간복잡도 강의 업데이트 했는데 안보셨으면 참고 부탁드립니다. 전체 좌표를 다 하기 때문에 전체적으로 보면 O(N)이나 이는 입력받으면서 진행하기 때문에 큰 상관이 없습니다.

    for(int i = 0; i < n; i++){
        cin >> x >> y;
        x += 500000;
        y += 500000;

1-E질문입니다!

0

518

2

3-L 틀린 부분 피드백 부탁드립니다.

0

822

2

1-A문제 순열재귀함수 질문입니다.

0

386

1

1-A 일곱난쟁이문제입니다

0

459

1

문제 풀 때 방향성에 대해

0

801

1

맥에서 vs code로 실행 관련 질문입니다

0

523

1

17071번 메모리 초과

0

386

1

1-C질문입니다!

0

423

2

2-B BFS 시간초과질문

0

630

2

1-O 13번 라인

0

443

1

6-J 놀이공원 문제 질문

0

381

1

구현관련 질문

0

484

1

강의 교안

0

320

1

실력을 더 올리고나서 강의를 보는 것이 맞을까요?

0

545

1

안녕하세요! 재귀함수에 관해서 질문드립니다

0

536

1

1-K

0

474

2

3-G번 질문있습니다.

1

474

3

3-C 실행 시간 질문드립니다.

0

494

1

4-A 문제 풀이 질문있습니다.

0

590

2

비트마스킹 연산자 "1의 보수" 영문 표기법

0

435

1

격자탐색 문제에서 BFS 시간복잡도 질문드립니다.

0

335

1

3-O go 함수 질문 드립니다.

1

448

2

4-A 출력 질문

0

305

1

1주차 1-O 질문드립니다

0

259

1