본문 바로가기
프로그래머스

[프로그래머스] 약수의 개수와 덧셈

by 소금_msg 2022. 12. 2.
import java.util.*;

class Solution {
    
    //약수를 입력받아 약수의 개수를 리턴
    public List<Integer> factor(int left, int right){
        int cnt = 0;
        List<Integer> evenOdd = new ArrayList<>();
        for(int i=left; i<= right; i++){
            // 약수 cnt 초기화
            cnt = 0;
            for(int j=1; j<=i; j++){
                if(i%j ==0){
                    cnt++;
                    
                }   
            }
            evenOdd.add(cnt);
        }
        
        return evenOdd;
    }
    
    
    
    public int solution(int left, int right) {
       List<Integer> evenOdd = factor(left, right);
        
        int answer = 0;
        int even = 0;
        int odd = 0;
        int tmp = right-left+1;
        int [] leftRight = new int[tmp];
        
        // left부터 right 까지 수가 들어있는 배열
        for(int i=0; i<leftRight.length;i++){
            leftRight[i] = left;
            left++;
        }
        
        //해당 수의 약수가 짝수인지 홀수인지 체크
        for(int i=0; i<evenOdd.size();i++){
            if(evenOdd.get(i)%2==0){
                even+=leftRight[i];
            }else{
                odd += leftRight[i];
            }
            
        }
    
        answer = even-odd;
        
        return answer;
    }
}