울음참고 개발공부
article thumbnail
728x90

 

https://school.programmers.co.kr/learn/courses/30/lessons/181859

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

 


 

[ 문제 설명 ]

 

 

 

 

문제에 따르면 i 가 arr[] 길이보다 작을 때 조건을 수행하며 i에 +1 씩 증가시키라고 하는 것을 보아 , 

for 문을 수행하면 될 것 같단 생각이 든다. 

 

반복문을 돈다고 가정하고, 그 안에서 조건을 요약하면 이렇다.

  • stk 가 비었으면 arr[ i ] 추가
  • stk 마지막 원소와 arr[ i ] 가 같음 -> stk 마지막 원소 제거
  • stk 마지막 원소와 arr[ i ] 가 다름 -> arr[ i ] 추가

 

 

 

 

[ 입출력 예 ]

 

주어진 예시 중 첫번째 입출력 예시를 살펴보자 

 

 

 

 

 

 

표에서는 마지막 원소가 다를 때 비교를 순서로 그려봤다. 

 

문제에 따라 작성한 조건문

stk 는 동적임으로(길이가 정해져있지않음) 먼저 리스트로 생성한다.

조건에 따라 i를 1씩 추가해주는 반복문은 다음과 같다
for(int i=0; i<arr.length(); i++){
	// 빈 배열인 경우, 마지막 원소 같은경우, 마지막 원소 다른경우 
}


 

 

 

처음에 stk 가 비어있으니 arr[0] 에 해당하는 원소 0 을 stk 에 추가한다.

 

그다음, 

1번 -> stk 의 마지막 원소와 arr [i] 의 원소인 1을 비교한다

2번 -> 원소가 다른 것을 확인하고 규칙을 확인한다

3번 -> 규칙에 따라, arr [i] 의 원소 1을 stk 에 추가한다. 

 

 

 

 


 

 

 

import java.util.*;

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

        return answer;
    }
}

 

 

 

 

728x90
profile

울음참고 개발공부

@메각이

포스팅이 좋았다면 "좋아요❤️" 또는 "구독👍🏻" 해주세요!