티스토리 뷰
C++이 지원하는 cout과 cin 함수가 C의 scanf, printf 보다 느리다는 사실은 많은 사람들이 알고 있다.
알고리즘 문제를 풀면서 입출력 시간이 크게 중요하지 않은 경우에는 C++의 입출력 함수가 쉽기 때문에 주로 사용을 했는 데, 많은 사람들이 속도를 위해서 C의 입출력 함수를 사용한다.
과연 속도가 얼마나 차이가 날지 궁금했다.
실험은 알고리즘 문제 풀이 과정에서 입출력 부분만 바꿔서 실험해보았다.
일반적으로 입출력의 병목현상이 심할 경우에 혹은, 입출력 함수의 비중이 큰 경우 일수록 크게 차이가 날 것이다.
다만 이 몇 가지 실험이 모든 일반적인 경우를 포함하지는 못하므로 참고용으로만 보면 좋을 것 같다.
SWexpert 아카데미에 있는 문제들로 테스트를 해보았다.
다른 코드는 동일하게 사용을 하고, 입출력 함수만 바꾸어 실행 시간이 어떻게 변하는 지 확인해봤다.
위에서 부터
1. C의 입출력 함수
2. C++의 입출력 함수 + ios::sync_with_stdio(0);
3. C++의 입출력 함수
순으로 실행 시간을 나타낸다.
첫 번째의 test 경우에는 최대와 최소의 차이가 약 1.5% 정도의 차이로 작다.
하지만 두 번째(C++의 입출력 함수 + ios::sync_with_stdio(0);) 경우가 가장 빨랐다.
두 번째의 실험에서도 세 번째가 가장 느렸고 두 번째가 가장 빨랐다. 20% 이상의 차이를 보여줬다.
세 번째 실험 결과도 마찬가지 였다.
결과를 확인해보니 C++의 입출력 함수를 이용하고
ios::sync_with_stdio(0);
cin.tie(0);
위의 코드를 추가해주는 것이 가장 실행시간이 빠르게 나타났다.
ios::sync_with_stdio(0); 에 대해서
'Programming Languages > C++ & Algorithm' 카테고리의 다른 글
2의 n승 개의 경우 모두 확인하기. (0) | 2020.10.07 |
---|---|
C++ 자료형 확인, 자료형 크기 확인 (0) | 2020.10.06 |
c++ 재귀 알고리즘을 이용한 조합(combination) 생성 (0) | 2020.09.28 |
c++ 2차원 동적배열의 참조에 의한 호출 (0) | 2020.09.24 |
C++ 반복자 , lower_bound, sort, unique, erase... (0) | 2020.09.23 |