코딩테스트

프로그래머스 코딩테스트(빈 배열에 추가, 삭제하기, 소인수분해, 7의 개수)

SOME코딩 2023. 5. 31. 18:36

<빈 배열에 추가, 삭제하기>

문제 설명
아무 원소도 들어있지 않은 빈 배열 X가 있습니다. 길이가 같은 정수 배열 arr과 boolean 배열 flag가 매개변수로 주어질 때, flag를 차례대로 순회하며 flag[i]가 true라면 X의 뒤에 arr[i]를 arr[i] × 2 번 추가하고, flag[i]가 false라면 X에서 마지막 arr[i]개의 원소를 제거한 뒤 X를 return 하는 solution 함수를 작성해 주세요.

 

풀이

import java.util.Arrays;
class Solution {
    public int[] solution(int[] arr, boolean[] flag) {
        int num = 0;
        for(int i=0;i<arr.length;i++){
            if(flag[i]){
                num+=(arr[i]*2);
            }
        }
        int[] arr1 = new int[num];
        int index = 0;
        for(int j=0;j<arr.length;j++){
            if(flag[j]){
                for(int k=0;k<arr[j]*2;k++){
                    arr1[index+k] = arr[j];
                }
                index += (arr[j]*2);
            } else {
                for(int l=1;l<=arr[j];l++){
                    arr1[index-l] = 0;
                }
                index -= arr[j];
            }
        }
        return Arrays.copyOf(arr1,index);
    }
}

 

다른 사람 풀이

import java.util.*;

class Solution {
    public int[] solution(int[] arr, boolean[] flag) {
        List<Integer> list = new ArrayList<>();
        for(int i = 0; i < arr.length; i++) {
            if(flag[i] == true) 
                 for(int j = 0; j < arr[i]*2; j ++)
                    list.add(arr[i]);
            else 
                for(int j = 0; j < arr[i]; j ++)
                    list.remove(list.size()-1);
        }
        return list.stream().mapToInt(i->i).toArray();
    }
}

 

<소인수분해>

문제 설명
소인수분해란 어떤 수를 소수들의 곱으로 표현하는 것입니다. 예를 들어 12를 소인수 분해하면 2 * 2 * 3 으로 나타낼 수 있습니다. 따라서 12의 소인수는 2와 3입니다. 자연수 n이 매개변수로 주어질 때 n의 소인수를 오름차순으로 담은 배열을 return하도록 solution 함수를 완성해주세요.

 

풀이

import java.util.*;
class Solution {
    public int[] solution(int n) {
        List<Integer> list = new ArrayList<>();
        for(int i=2;i<=n;i++){
            if(n%i==0){
                while(n%i==0){
                    n/=i;
                }
                list.add(i);
            }
            if(n==1) break;
        }
        
        return list.stream().mapToInt(i->i).toArray();
    }
}

 

<7의 개수>

문제 설명
머쓱이는 행운의 숫자 7을 가장 좋아합니다. 정수 배열 array가 매개변수로 주어질 때, 7이 총 몇 개 있는지 return 하도록 solution 함수를 완성해보세요.

 

풀이

class Solution {
    public int solution(int[] array) {
        int answer = 0;
        for(int i:array){
            while(i!=0){
                if(i%10==7){
                    answer++;
                }
                i/=10;
            }
        }
        return answer;
    }
}