문제 링크 https://programmers.co.kr/learn/courses/30/lessons/12977
문제
주어진 숫자 중 3개의 수를 더했을 때 소수가 되는 경우의 개수를 구하려고 합니다. 숫자들이 들어있는 배열 nums가 매개변수로 주어질 때, nums에 있는 숫자들 중 서로 다른 3개를 골라 더했을 때 소수가 되는 경우의 개수를 return 하도록 solution 함수를 완성해주세요.
제한사항
- nums에 들어있는 숫자의 개수는 3개 이상 50개 이하입니다.
- nums의 각 원소는 1 이상 1,000 이하의 자연수이며, 중복된 숫자가 들어있지 않습니다.
풀이 과정
소수 찾는 알고리즘은 에라토스테네스의 체를 사용했다.
3개의 수를 더할 때는 3중 for문을 사용하여 더해주었고,
더한 값을 num 배열에 담았을 때 0이 아니면 소수이므로 카운트해준다.
풀이1
#include <vector>
#include <iostream>
#include <cmath>
using namespace std;
const int NUM = 3000;
int num[NUM];
void PrimeNum(){
for(int i = 2; i <= NUM; i++){
num[i] = i;
}
for(int i = 2; i <= sqrt(NUM); i++){
if(!num[i]) continue;
for(int j = i * i; j <= NUM; j += i){
num[j] = 0;
}
}
}
int solution(vector<int> nums) {
int answer = 0;
PrimeNum();
for(int i = 0; i < nums.size() - 2; i++){
for(int j = i + 1; j < nums.size() - 1; j++){
for(int k = j + 1; k < nums.size(); k++){
int sum = nums[i] + nums[j] + nums[k];
if(num[sum]) answer++;
}
}
}
return answer;
}
풀이2
#include <vector>
#include <iostream>
using namespace std;
const int NUM = 3000;
int num[NUM];
// sqrt 함수 구현
int sqrt(int n){
int s = 0;
int t = 0;
s = n / 2;
while(s != t){
t = s;
s = ((n / t) + t) / 2;
}
return s;
}
void PrimeNum(){
for(int i = 2; i <= NUM; i++){
num[i] = i;
}
for(int i = 2; i <= sqrt(NUM); i++){
if(!num[i]) continue;
for(int j = i * i; j <= NUM; j += i){
num[j] = 0;
}
}
}
int solution(vector<int> nums) {
int answer = 0;
PrimeNum();
for(int i = 0; i < nums.size() - 2; i++){
for(int j = i + 1; j < nums.size() - 1; j++){
for(int k = j + 1; k < nums.size(); k++){
int sum = nums[i] + nums[j] + nums[k];
if(num[sum]) answer++;
}
}
}
return answer;
}
댓글남기기