MapleStory Finger Point

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

ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค - java ์ง„๋ฃŒ์ˆœ์„œ ์ •ํ•˜๊ธฐ

HYEJU01 2024. 5. 15. 18:34
์ฒด๊ฐ Level : โ˜… โ˜… โ˜†
Review: ๋ฐฐ์—ด์˜ ์ •๋ ฌ๊ณผ ๋ฐฐ์—ด ์ธ๋ฑ์Šค ํ™œ์šฉ!! 

 

๐Ÿ’ก ์‘๊ธ‰๋„๊ฐ€ ๋†’์€ ์ˆœ์„œ๋Œ€๋กœ ์ง„๋ฃŒ์ˆœ์„œ๋ฅผ ํ‘œ๊ธฐํ•˜๋Š” ๊ฒƒ์ด๋‹ค.

 

๋ญ”๊ฐ€ ๋”ฑ ๋“  ์ƒ๊ฐ์ด ๋ฐฐ์—ด์ธ๋ฑ์Šค์™€ ํฐ๊ฐ’ ์ •๋ ฌ์ด์—ˆ๋‹ค.

max ๊ฐ’์„ ํ•˜๋‚˜์”ฉ ์ฐพ์•„๊ฐ€์•ผํ•˜๋‚˜ ์‹ถ์—ˆ๋Š”๋ฐ ๋„ˆ๋ฌด ๋ณต์žกํ•ด์กŒ๊ณ 

์ฐจ๋ผ๋ฆฌ ์ •๋ ฌ์„ ํ•ด๋ฒ„๋ ค์„œ ๊ทธ ์ธ๋ฑ์Šค๋ฅผ ์ด๋ฆฌ์ €๋ฆฌ ํ•˜๋ฉด ๋‹ต์ด ๋‚˜์˜ค๊ฒ ๊ตฌ๋‚˜! ์‹ถ์—ˆ๋‹ค.

 

1) ๋จผ์ € ๋ฐฐ์—ด์„ ๋ณต์‚ฌํ•ด์ฃผ๊ณ  ๋‘˜์ค‘ ํ•˜๋‚˜๋ฅผ ์ •๋ ฌ์‹œ์ผœ์ค€๋‹ค.

์ด๋•Œ ํŽธํ•˜๊ฒŒ ๋‚ด๋ฆผ์ฐจ์ˆœ ์ •๋ ฌ์„ ํ•ด์ฃผ๋ ค๊ณ  ํ–ˆ์ง€๋งŒ

์˜ค๋ฆ„์ฐจ์ˆœ ์ •๋ ฌ์ผ๋•Œ๋กœ ๋„์ „ํ•ด๋ดค๋‹ค. !!

 

2) 2์ค‘ for ๋ฌธ์„ ํ†ตํ•ด์„œ ๋ฐฐ์—ด์„ ์ˆœํšŒํ•˜๋ฉด์„œ ์›๋ณธ๋ฐฐ์—ด๊ณผ

๊ฐ™์€ ๊ฐ’์„ ๊ฐ€์ง„ ๋ณต์‚ฌ๋ฐฐ์—ด์˜ "์œ„์น˜" ๋ฅผ ์ฐพ์•„์ค„ ๊ฒƒ์ด๋‹ค.

 

์ด๋•Œ ์˜ค๋ฆ„์ฐจ์ˆœ ์ •๋ ฌ์„ ํ–ˆ๊ธฐ๋•Œ๋ฌธ์— ์ธ๋ฑ์Šค๋ฅผ ๋ฐ”๋กœ ๊ฐ€์ ธ์˜ค๋ฉด ์•ˆ๋œ๋‹ค!!

์‘๊ธ‰๋„๊ฐ€ ์ œ์ผ ๋‚ฎ์€ ์ˆ˜(3) ๊ฐ€ = ์ž‘์€ ์ˆ˜ (1) ๋ฅผ ๊ฐ€์ง€๊ฒŒ๋œ๋‹ค.

 

์ฆ‰ ๋ฐฐ์—ด๊ธธ์ด - ๋ณต์‚ฌ๋ฐฐ์—ด์˜ ์ธ๋ฑ์Šค๊ฐ’ ์„ ํ†ตํ•ด์„œ

์‘๊ธ‰๋„๊ฐ€ ์ œ์ผ ๋‚ฎ์€ ์ˆ˜ (3) ๊ฐ€ ํฐ ์ˆ˜ (3-0 = 3)์„ ๊ฐ€์ง€๋„๋ก ํ•ด์•ผํ•œ๋‹ค.

import java.util.Arrays;

class Solution {
    public int[] solution(int[] emergency) {
        int[] answer = new int [emergency.length];

        for (int i = 0; i < emergency.length; i++){
            answer[i] = emergency[i];
        }
        Arrays.sort(emergency);
        
        int len = emergency.length;
        
        for (int i = 0; i <emergency.length; i++){
            for(int j = 0; j<emergency.length; j++){
                if (answer[j] == emergency[i]) {// ์ฐจ๋ก€๋Œ€๋กœ ๊ฐ™์€๊ฐ’ ์ฐพ๊ธฐ
                    emergency[i] = len - j;
                    break;
                }
            }
            
        }
        
        return emergency;
    }
}