문제 주소입니다.
https://programmers.co.kr/learn/courses/30/lessons/12977
1. 문제 설명
2. 문제 해석
3. 소스 코드
4. 결과
1. 문제 설명
주어진 숫자 중 3개의 수를 더했을 때 소수가 되는 경우의 개수를 구하려고 합니다. 숫자들이 들어있는 배열 nums가 매개변수로 주어질 때, nums에 있는 숫자들 중 서로 다른 3개를 골라 더했을 때 소수가 되는 경우의 개수를 return 하도록 solution 함수를 완성해주세요. |
제한사항
|
예시
입출력 예
2. 문제풀이
1. dfs를 이용하여 숫자 3개를 더한 모든 수를 구한다. |
3. 소스코드
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
32
33
34
35
36
37
38
|
#include <vector>
#include <iostream>
#include <cmath>
using namespace std;
vector<int> tempList;
bool primeNumber(int a) {
for (int i = 2; i <= sqrt(a); i++)
if (a % i == 0)//i가 나누어떨어지면 소수가 아님
return false;
return true;
}
void serch(vector<int>& nums, int index = 0, int count=0, int sum = 0) {
if (index >= nums.size())
return;
sum += nums[index];
for (int i = index; i < nums.size(); i++) {
if (count == 2) {
tempList.push_back(sum);
return;
}
else
serch(nums, i+1, count+1, sum);
}
}
int solution(vector<int> nums) {
int answer = 0;
for (int i = 0; i < nums.size()-2; i++)
serch(nums, i);
for (auto a : tempList) {
if (primeNumber(a))
answer++;
}
return answer;
}
|
4. 결과
'코딩테스트 > 프로그래머스' 카테고리의 다른 글
역순 정렬하기 MYSQL(프로그래머스) (0) | 2020.07.06 |
---|---|
모든 레코드 조회하기 MYSQL(프로그래머스) (0) | 2020.07.04 |
124 나라의 숫자 C++[프로그래머스] (0) | 2020.05.10 |
예상 대진표 C++(팁스다운)[프로그래머스] (0) | 2020.05.09 |
영어 끝말잇기 C++(섬머/윈터코딩)[프로그래머스] (0) | 2020.05.08 |
댓글