inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

Do it! 알고리즘 코딩테스트 with Python

[구간 합 실전 문제] 구간 합 구하기 2 (백준 11660)

Python sys.stdin.readline() 사용

550

조수민

작성한 질문수 1

0

안녕하세요.

구간합구하기 (백준 11660) 문제를 풀고 있는데요.

코드는 똑같은데, 제일 상단에 아래 코드 입력 여부에 따라 시간초과/성공이 갈립니다.

import sys

input = sys.stdin.readline

 

이게 실패와 성공을 가를만큼 중요한 역할을 하나요?

위 코드를 넣으면 왜 빨라지는지 설명해주실 수 있으실까요?

python 코딩-테스트 알고리즘

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

네, input = sys.stdin.readline 코드는 Python에서 입력을 받는 속도를 향상시켜주는 역할을 합니다.
기본적으로 Python의 input() 함수는 사용자의 입력을 받으면서, 공백문자(예: 줄바꿈)를 제거하는 등의 추가적인 작업을 수행하기 때문에 상대적으로 느릴 수 있습니다.
반면 sys.stdin.readline은 줄바꿈 문자를 포함한 한 줄의 문자열을 빠르게 입력받기 때문에, 많은 양의 데이터를 빠르게 입력받아야 하는 경우 (예: 알고리즘 문제에서의 대량의 데이터 입력)에 훨씬 효율적입니다.

다만, sys.stdin.readline을 사용할 때에는 문자열의 마지막에 줄바꿈 문자가 포함되기 때문에, 이를 제거하기 위해 종종 strip()을 사용해야 할 수 있습니다.

따라서 알고리즘 문제를 풀 때 입출력의 양이 많고 빠른 입출력이 요구되는 경우, input() 대신 sys.stdin.readline을 사용하여 시간 초과를 방지할 수 있습니다.

문제 푸시느라 수고 많으십니다. 질문이 더 있으시면 언제든 질문해주세요.

실제 계좌 잔고 및 테스트중에

1

14

2

Replit UI 변경으로 인한 실습 진행 문의

1

10

1

문제를 고민하는 시간 관련

0

9

2

29강 5:00

0

15

2

코딩살구클럽

0

14

1

설치 및 설정 가이드 노션 자료는 없나요 ?

0

16

2

실기시험 제출관련

0

124

2

6.20 작업형 2 과적합

0

138

3

install까지 설치 하였는데 start 가안됩니다.

1

21

1

8분54초 테이블 내용 문의

0

18

1

코딩팡 장업형2 베이스 라인 인코딩 종류 질문

0

38

2

multi_tool_agent.py 에서 arxiv tool 에러

0

16

1

코딩살구클럽 문의

0

26

2

로지스틱회귀, 회귀

0

46

2

가상 환경과 차이 도커 질문

0

24

1

자료 다운로드 위치 확인 부탁드립니다.

0

14

1

회귀 문제를 풀때 질문입니다.

0

52

1

불균형 처리 후 성능이 더 낮아졌다면,

0

60

2

실기 체험 제2유형 에러 문의

0

60

1

병합정렬이 홀수개의 숫자에 적용될 경우?

0

124

0

다익스트라와 벨만-포드 차이에서

0

334

2

나머지 합 구하기 핵심 아이디어 문의

0

231

1

17298 오큰수 구하기 질문있습니다.

1

696

2

디버깅에 관한 질문

1

656

1