MapleStory Finger Point

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

ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค - java ์ˆ˜์—ด๊ณผ ๊ตฌ๊ฐ„ ์ฟผ๋ฆฌ 2

HYEJU01 2024. 4. 26. 21:51

์กฐ๊ฑด์‹์—์„œ k ๋ณด๋‹ค ํฌ๋ฉด์„œ !! ๊ฐ€์žฅ ์ž‘์€ !! << ์ด ์กฐ๊ฑด์„ ๋งŒ๋“ค์ง€ ๋ชปํ•ด์„œ  ๋‹ค๋ฅธ ์ฝ”๋“œ๋ฅผ ์ฐธ๊ณ ํ–ˆ๋‹ค. ๐Ÿ˜ญ๐Ÿ˜ญ

์ตœ์†Ÿ๊ฐ’ ๊ตฌํ•˜๋Š” ์•Œ๊ณ ๋ฆฌ์ฆ˜๋„ ๋„ฃ์–ด๋ณด๋ฉด์„œ ํ•ด๋ดค์ง€๋งŒ ์–ด๋””์„œ ์กฐ๊ฑด์ด ์•ˆ๋งž๋Š”์ง€ ์ž๊พธ ์˜ค๋ฅ˜๊ฐ€ ๋‚ฌ๋‹ค..

๋‹ค๋ฅธ๊ฑฐ ์ฐธ๊ณ ํ• ๊นŒ ๊ณ„์† ๊ณ ๋ฏผํ•˜๋‹ค๊ฐ€ ํ•œ๋ฒˆ ํ•ด๋ณด์ž ํ–ˆ์ง€๋งŒ ...  ์‹œ๊ฐ„ ์—„์ฒญ ๋‚ ๋ฆฐ .... ๐Ÿ˜ญ๐Ÿ˜ญ

 

๐Ÿคฎ ์‹คํŒจํ•œ ์ฝ” ๋“œ

class Solution {
    public int[] solution(int[] arr, int[][] queries) {
        int[] answer = new int[queries.length]; //3
        int num = 0;
        
         for (int i = 0 ; i < queries.length; i++){ //0~2
            for (int j = arr[(queries[i][num])]; j < arr[(queries[i][num+1])];  j++){
                //0~4
                if (arr[j] > arr[queries[i][num+2]]){ // 2 ํฌ๊ณ  ์ œ์ผ ์ž‘์€ ๊ฐ’
                    answer[i]  = arr[j];
                }
                else {
                    answer[i] = -1;
                }
            }
         }
        
        return answer;
    }
}

 

import java.util.ArrayList;
import java.util.Arrays;

public class Solution {
    public static int[] solution(int[] arr, int[][] queries) {
        int[] answer = new int[queries.length];
        Arrays.fill(answer, -1); // ์ดˆ๊ธฐ๊ฐ’์œผ๋กœ -1์„ ์ฑ„์›Œ๋†“์Šต๋‹ˆ๋‹ค.

        for (int i = 0; i < queries.length; i++) {
            int s = queries[i][0];
            int e = queries[i][1];
            int k = queries[i][2];

            int minGreaterValue = Integer.MAX_VALUE; // ์ตœ์†Œ๊ฐ’์„ ์ €์žฅํ•  ๋ณ€์ˆ˜, ์ผ๋‹จ ์ตœ๋Œ€๊ฐ’์œผ๋กœ ์ดˆ๊ธฐํ™”ํ•ฉ๋‹ˆ๋‹ค.

            for (int j = s; j <= e; j++) {
                if (arr[j] > k && arr[j] < minGreaterValue) {
                    minGreaterValue = arr[j];
                }
            }
            if (minGreaterValue != Integer.MAX_VALUE) {
                answer[i] = minGreaterValue;
            }
        }
        return answer;
    }

}

 

๊ฐ„ํŽธํ•˜๊ฒŒ ์ดˆ๊ธฐ๊ฐ’์„ -1๋กœ ์ฑ„์›Œ๋„ฃ๊ณ  

k ๋ณด๋‹ค ํฌ๋ฉด์„œ ๊ฐ€์žฅ ์ž‘์€ ๊ฐ’ => if (arr[j] > k && arr[j] < minGreaterValue)

 

min ๊ฐ’์„ ์ตœ๋Œ€๊ฐ’์œผ๋กœ ์ง€์ •ํ•ด์„œ ํ•˜๋‚˜์”ฉ ๋น„๊ตํ•œ๋‹ค.  

 

 

๐Ÿ’ฌ Integer.MAX_VALUE  : Integer.MAX_VALUE๋Š” ์ž๋ฐ”์—์„œ ์ •์ˆ˜ํ˜•(int) ๋ณ€์ˆ˜๊ฐ€ ๊ฐ€์งˆ ์ˆ˜ ์žˆ๋Š” ์ตœ๋Œ€๊ฐ’์„ ๋‚˜ํƒ€๋‚ด๋Š” ์ƒ์ˆ˜์ž…๋‹ˆ๋‹ค. ์ด ๊ฐ’์€ 2^31 - 1, ์ฆ‰ 2,147,483,647