MapleStory Finger Point

๐Ÿƒ‍โ™€๏ธprogrammers/Java

ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค - java ๋นˆ ๋ฐฐ์—ด์— ์ถ”๊ฐ€, ์‚ญ์ œํ•˜๊ธฐ

HYEJU01 2024. 5. 8. 14:15

 

 ๐Ÿ’ก flag ๊ฐ’์— ๋”ฐ๋ผ arr ์— ์žˆ๋Š” ๊ฐ’๋“ค์„ ์ถ”๊ฐ€ํ•˜๊ณ  ์ œ๊ฑฐํ•ด์•ผํ•œ๋‹ค.

 

flag ๊ธธ์ด์™€ arr ๊ธธ์ด๋Š” ๋™์ผํ•˜๋‹ค.

flag ๋ฅผ 1์ฐจ๋กœ ๋Œ๋ ค์ฃผ๋ฉด์„œ flag ๊ฐ’์ด T & F ์ธ์ง€ ํŒ๋‹จํ•ด์ค€๋‹ค.

1. ์ฐธ์ด๋ฉด arr[i] ๋ฅผ arr[i] *2 ๋ฒˆ ๋ฐ˜๋ณตํ•ด์ค€๋‹ค.

2. ๊ฑฐ์ง“์ด๋ฉด arr[i] ๋งŒํผ ์ง€์šด๋‹ค.  (์ง€์šธ๋•Œ๋Š” ๋’ค์—์„œ๋ถ€ํ„ฐ remove)

 

 

 ๐Ÿ’ฌ ๋ฐฐ์—ด์€ switch ๊ฐ’์— ์‚ฌ์šฉ ๋ถˆ๊ฐ€ : flag ๋ฐฐ์—ด์ด boolean ๋ฐฐ์—ด๋กœ ์„ ์–ธ๋˜์–ด์„œ, switch๋ฌธ ๋Œ€์‹  if-else ๋ฌธ์„ ์‚ฌ์šฉํ•ด์ค˜์•ผํ•œ๋‹ค.

 ๐Ÿ’ฌ arr.size() :: ๋ฐฐ์—ด์˜ ํฌ๊ธฐ๋ฅผ ๋ฐ˜ํ™˜ํ•œ๋‹ค.

import java.util.ArrayList;

class Solution {
    public ArrayList<Integer> solution(int[] arr, boolean[] flag) {
        ArrayList<Integer> answer = new ArrayList<Integer>();
        
       
        for (int i = 0; i < flag.length; i++){
                if (flag[i] == true){  //flag ๊ฐ€ ์ฐธ์ด๋ฉด arr[i] * 2 ๋งŒํผ ์ถœ๋ ฅ
                    for (int j = 0; j < arr[i]*2; j++){
                        answer.add(arr[i]);
                    }
                }else{ // ๊ฑฐ์ง“์ด๋ฉด arr[i] 
                    for (int j = 0; j < arr[i]; j++){
                     answer.remove(answer.size()-1);
                    }
                }

        }//for
        
        return answer;
    }
}