본문 바로가기

코딩테스트

프로그래머스 코딩테스트 배열만들기4

배열만들기4

 

출처: 프로그래머스 코딩 테스트 연습, https://school.programmers.co.kr/learn/challenges

 

코딩테스트 연습 | 프로그래머스 스쿨

개발자 취업의 필수 관문 코딩테스트를 철저하게 연습하고 대비할 수 있는 문제를 총망라! 프로그래머스에서 선발한 문제로 유형을 파악하고 실력을 업그레이드해 보세요!

school.programmers.co.kr

문제 설명 : 정수 배열 arr가 주어집니다. arr를 이용해 새로운 배열 stk를 만드려고 합니다. 변수 i를 만들어 초기값을 0으로 설정한 후 i가 arr의 길이보다 작으면 다음 작업을 반복합니다. 만약 stk가 빈 배열이라면 arr[i]를 stk에 추가하고 i에 1을 더합니다. stk에 원소가 있고, stk의 마지막 원소가 arr[i]보다 작으면 arr[i]를 stk의 뒤에 추가하고 i에 1을 더합니다. stk에 원소가 있는데 stk의 마지막 원소가 arr[i]보다 크거나 같으면 stk의 마지막 원소를 stk에서 제거합니다.

위 작업을 마친 후 만들어진 stk를 return 하는 solution 함수를 완성해 주세요.


 

최종 코드 :

import java.util.ArrayList;

class Solution {
    public int[] solution(int[] arr) {
        ArrayList<Integer> stkArray = new ArrayList<Integer>();

        for(int i = 0; i < arr.length; i++){
            if(stkArray.size() == 0 || stkArray.get(stkArray.size()-1) < arr[i]){
                stkArray.add(arr[i]);
            } else {
                int last = stkArray.get(stkArray.size() - 1);
                while (!stkArray.isEmpty() && last >= arr[i]) {
                    stkArray.remove(stkArray.size() - 1);
                    if (!stkArray.isEmpty()) {
                        last = stkArray.get(stkArray.size() - 1);
                    }
                }
                stkArray.add(arr[i]);
            }
        }
        
        int[] stk = new int[stkArray.size()];
        for(int i = 0; i < stkArray.size(); i++){
            stk[i] = stkArray.get(i);      
        }
        
        return stk;
    }
}

두번째 :

import java.util.ArrayList;

class Solution {
    public int[] solution(int[] arr) {
        ArrayList<Integer> stkArray = new ArrayList<Integer>();
        
        for(int i = 0; i < arr.length; i++ ) {
            if(stkArray.size() == 0 || stkArray.get(stkArray.size() - 1) < arr[i]) {
                stkArray.add(arr[i]);
              //  i += 1;
            } else if(stkArray.get(stkArray.size() - 1) >= arr[i]) {
                stkArray.remove(stkArray.size() - 1);
               // i += 1;
            }
        }
        
        int[] stk = new int[stkArray.size()];
        for (int i = 0; i < stkArray.size(); i++) {
            stk[i] = stkArray.get(i);
        }
        
        return stk;
    }
}

 

처음코드 :

import java.util.ArrayList;

class Solution {
    public int[] solution(int[] arr) {
        ArrayList<Integer> stkArray = new ArrayList<Integer>();
       
        for(int i = 0; i < arr.length; i++){
            if(stkArray.size() == 0 ){
                stkArray.add(arr[i]);
                i += 1 ;  
            }else if(stkArray.get(stkArray.size()-1) < arr[i]){
                stkArray.add(arr[i]);
                i += 1 ;
            }else if(stkArray.get(stkArray.size()-1) >= arr[i]){
                stkArray.remove(stkArray.size()-1);
            }else {
                
            }
        }
        int[] stk = new int[stkArray.size()];
        for(int i =0;i < stkArray.size();i++){
      stk[i] = stkArray.get(i);      
        }
        return stk;
    }
}

ㅠㅠ ... 흑흑.. 어려워

728x90
300x250