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

이상목님의 프로필 이미지
이상목

작성한 질문수

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

1-O

cnt %= n을 추가함으로써 시간초과 -> 성공 으로 되는것이 이해가 어렵습니다...

작성

·

417

0

안녕하세요. 선생님

좋은 강의 잘 듣고있는 취준생입니다..

1-O강의에 대해 질문이 있습니다.

cnt %= n을 추가함으로서 시간초과를 해결하였는데 , 이유가 무엇인지 궁금합니다. 제 생각에는 이 코드를 추가하면 계산량이 많아져서 시간이 더 오래걸릴 것이라 생각했습니다.

cnt의 값이 커지면 cnt*10 + 1을 하는 것이 더 오래걸려서 그런건가요?..

알려주시면 감사하겠습니다!

답변 1

1

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

안녕하세요 상목님 ㅎㅎ

곱하기 연산에 대한 시간은 O(1) 정도로 매우 작은 시간복잡도입니다.

다만, 그냥 *를 하고 모듈러연산을 적용하지 않고 제출했을 때 시간초과가 뜨는 것은 UB로 인한 시간초과인 것 같습니다. long long 으로도 커버 불가능한 숫자인 이상한 숫자가 나오니 거기에 따라 %을 했을 때 우리가 예측하는 %연산 자체가 안 될 것이고 거기에 따라 불필요한 %연산이 계속해서 실행되는 것이죠. 거기에 따른 시간초과인 것 같습니다.

 

또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제가 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

이상목님의 프로필 이미지
이상목
질문자

감사합니다! 선생님

이상목님의 프로필 이미지
이상목

작성한 질문수

질문하기