Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- 프로그래머스 파이썬
- 자연어처리
- 백준
- 파이썬
- dacon
- ChatGPT
- Docker
- 프로그래머스
- 편스토랑
- 더현대서울 맛집
- gs25
- 우분투
- Baekjoon
- hackerrank
- PYTHON
- Real or Not? NLP with Disaster Tweets
- Git
- ubuntu
- Kaggle
- 금융문자분석경진대회
- leetcode
- 맥북
- github
- 코로나19
- SW Expert Academy
- 편스토랑 우승상품
- programmers
- 데이콘
- 캐치카페
- AI 경진대회
Archives
- Today
- Total
솜씨좋은장씨
[BaekJoon] 15719번 : 중복된 숫자 (Python) 본문
728x90
반응형
코딩 1일 1문제! 오늘의 문제는 백준 15719번 중복된 숫자입니다.
2달 전 부터 시도하였다가 메모리초과, 시간초과, 런타임에러에 시달리다 오늘 드디어 풀게 된 문제입니다.
👨🏻💻 문제 풀이
처음에는 엄청 쉽다고 생각한 문제여서 시도한 문제인데
첫째 줄에 주어지는 수열의 크기 N(2 ≤ N ≤ 10,000,000)의 최대 크기인 천만은 생각보다 큰 숫자였습니다.
split을 하여 리스트로 만들면 메모리 초과
그냥 반복문을 돌면서 값에 접근하려하면 시간초과가 발생했습니다.
시간초과는 언어를 Python3 -> PyPy3 로 변경하는 방법으로 해결하였고메모리초과는 split을 하지않고 반복문을 돌면서 합을 구하고 가우스의 덧셈 공식을 활용하여 N까지의 합을 구해 문제를 풀었습니다.
def get_range_sum(final_number):
return final_number * (final_number - 1) // 2
먼저 가우스의 덧셈 공식을 함수로 만들어 주었습니다.
import sys
N = int(input())
numbers = sys.stdin.read()
예제 입력은 sys의 stdin.read()를 활용했습니다.
sum_numbers = 0
temp = ""
for num in numbers:
if num.isdigit():
temp += num
elif num == " ":
sum_numbers += int(temp)
temp = ""
sum_numbers += int(temp)
반복문을 돌면서 입력받은 숫자에서 공백이 아닐때 temp에 이어붙여 숫자를 만들어주고
공백일 경우 지금까지 이어붙인 숫자들을 int형으로 변경한 뒤 sum_numbers에 더해주어
입력받은 모든 숫자들의 합을 만들어 줍니다.
sum_numbers - get_range_sum(N)
이렇게 모든 숫자를 더한 합의 결과와 1부터 N까지의 숫자의 합을 빼주면!
중복된 숫자를 알 수 있습니다.
전체 코드는 아래를 참고해주세요.
👨🏻💻 코드 ( Solution )
import sys
def get_range_sum(final_number):
return final_number * (final_number - 1) // 2
def duplicate_number(N, numbers):
sum_numbers = 0
temp = ""
for num in numbers:
if num.isdigit():
temp += num
elif num == " ":
sum_numbers += int(temp)
temp = ""
sum_numbers += int(temp)
return sum_numbers - get_range_sum(N)
if __name__ == "__main__":
N = int(input())
numbers = sys.stdin.read()
print(duplicate_number(N, numbers))
'Programming > 코딩 1일 1문제' 카테고리의 다른 글
[BaekJoon] 10797번 : 10부제 (Python) (0) | 2021.10.19 |
---|---|
[BaekJoon] 10039번 : 평균 점수 (Python) (0) | 2021.10.18 |
[BaekJoon] 5704번 : 팬그램 (Python) (0) | 2021.10.16 |
[BaekJoon] 11728번 : 배열 합치기 (Python) (0) | 2021.10.15 |
[BaekJoon] 2798번 : 블랙잭 (Python) (0) | 2021.10.14 |
Comments