Algorithm/백준
[백준 알고리즘] 15596번: 정수 N개의 합 (Python)
에릭 Kim
2023. 4. 22. 18:56
반응형
https://www.acmicpc.net/problem/15596
15596번: 정수 N개의 합
C++17, Java 8, Python 3, C11, PyPy3, C99, C++98, C++11, C++14, Go, C99 (Clang), C++98 (Clang), C++11 (Clang), C++14 (Clang), C11 (Clang), C++17 (Clang)
www.acmicpc.net
문제
정수 n개가 주어졌을 때, n개의 합을 구하는 함수를 작성하시오.
작성해야 하는 함수는 다음과 같다.
- C, C11, C (Clang), C11 (Clang): long long sum(int *a, int n);
- a: 합을 구해야 하는 정수 n개가 저장되어 있는 배열 (0 ≤ a[i] ≤ 1,000,000, 1 ≤ n ≤ 3,000,000)
- n: 합을 구해야 하는 정수의 개수
- 리턴값: a에 포함되어 있는 정수 n개의 합
- C++, C++11, C++14, C++17, C++ (Clang), C++11 (Clang), C++14 (Clang), C++17 (Clang): long long sum(std::vector<int> &a);
- a: 합을 구해야 하는 정수 n개가 저장되어 있는 배열 (0 ≤ a[i] ≤ 1,000,000, 1 ≤ n ≤ 3,000,000)
- 리턴값: a에 포함되어 있는 정수 n개의 합
- Python 2, Python 3, PyPy, PyPy3: def solve(a: list) -> int
- a: 합을 구해야 하는 정수 n개가 저장되어 있는 리스트 (0 ≤ a[i] ≤ 1,000,000, 1 ≤ n ≤ 3,000,000)
- 리턴값: a에 포함되어 있는 정수 n개의 합 (정수)
- Java: long sum(int[] a); (클래스 이름: Test)
- a: 합을 구해야 하는 정수 n개가 저장되어 있는 배열 (0 ≤ a[i] ≤ 1,000,000, 1 ≤ n ≤ 3,000,000)
- 리턴값: a에 포함되어 있는 정수 n개의 합
- Go: sum(a []int) int
- a: 합을 구해야 하는 정수 n개가 저장되어 있는 배열 (0 ≤ a[i] ≤ 1,000,000, 1 ≤ n ≤ 3,000,000)
- 리턴값: a에 포함되어 있는 정수 n개의 합
소스코드
풀이
★ sum 함수를 활용해서 푸는 방법과 함수 안에서 반복문을 활용하여 푸는 방법 2가지를 사용해봤습니다. sum 함수를 사용해서 결과 값을 구하는 방법에서 시간이 더 빠르게 나오는 것을 확인할 수 있습니다. 하지만 내장 함수를 사용하지 못하게 하는 경우도 있으니 for 반복문 방법도 알아놓으시면 좋을 듯 합니다 !
★ 문제 풀면서 계속 런타임 에러(importError)가 발생했었는데, 함수과 매개변수를 소스코드처럼 사용하지 않았기 때문입니다. 제출란에 들어가시면 소스코드가 나오는데 함수 이름과 매개변수명을 동일하게 사용해줘야 하는 거 같습니다.
★ 저는 제 마음대로 설정했다가 영문도 모르고 5번째만에 통과했습니다 ^^ ㅎㅎ
반응형