MapleStory Finger Point

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

ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค - java ์ตœ๋นˆ๊ฐ’ ๊ตฌํ•˜๊ธฐ

HYEJU01 2024. 5. 14. 17:19
์ฒด๊ฐ Level : โ˜…โ˜…โ˜†
Review: ๋ฐฐ์—ด ์ธ๋ฑ์Šค๋ฅผ ์ด์šฉํ•ด์„œ ์ตœ๋นˆ๊ฐ’ ๊ตฌํ•˜๋Š” ์•Œ๊ณ ๋ฆฌ์ฆ˜ + ์ค‘๋ณต๊ฐ’ ์ฐพ๊ธฐ !! 
๋ฐฐ์—ด์˜ ์ธ๋ฑ์Šค์™€ ๋ฐฐ์—ด์˜ ๊ฐ’์„ ์‘์šฉํ•ด์„œ ์‚ฌ์šฉํ•˜๊ธฐ!!!!

 

 ๐Ÿ’ก ๋ฐฐ์—ด์—์„œ ์ œ์ผ ๋งŽ์ด ๋‚˜์˜จ = ์ตœ๋นˆ๊ฐ’์ธ ์ˆซ์ž๋ฅผ ์ถœ๋ ฅํ•œ๋‹ค. (๊ฐœ์ˆ˜๊ฐ€ ์•„๋‹˜!!)

์—ฌ๊ธฐ์„œ ์ตœ๋นˆ๊ฐ’์ด ๋‘๊ฐœ ์ด์ƒ ๋‚˜์˜ค๋ฉด -1 ์„ ์ถœ๋ ฅํ•œ๋‹ค.

 

 

1) arr ๊ฐ’์— ๋Œ€์‘์‹œ์ผœ์„œ ๋™์ผํ•œ ๊ฐ’์ด ์žˆ๋Š”์ง€ ์นด์šดํŒ…ํ•˜๋Š” ๋ฐฉ์‹์œผ๋กœ ํ‘ผ๋‹ค!

2) ์ดํ›„ ์นด์šดํŒ…ํ•œ ๋ฐฐ์—ด ์ค‘  ์ตœ๋Œ€๊ฐ’์„ ์ฐพ๋Š”๋‹ค .

3) ๊ทธ ๊ฐ’์ด ์ตœ๋นˆ๊ฐ’์ด ๋˜๊ณ ,

4) ์—ฌ๊ธฐ์„œ ์ตœ๋นˆ๊ฐ’์ด ๋‘๊ฐœ์ด์ƒ์ด ๋‚˜์˜ค๋Š” ๊ฒฝ์šฐ๋ฅผ ์žก์•„์•ผํ•˜๋Š”๋ฐ.

4-1) ์ตœ๋Œ€ ์ตœ๋นˆ๊ฐ’ ๊ฐœ์ˆ˜์™€ ๊ฐ™์€ ๊ฐ’์ด ๋‚˜์˜ค๋ฉด , ์ตœ๋นˆ๊ฐ’์„ ๋กœ -1 ๋ฆฌํ„ดํ•œ๋‹ค.

 

- ๋ฐฐ์—ด์˜ ๊ฐ’ => ๊ฐœ์ˆ˜

- ๋ฐฐ์—ด์˜ ์ธ๋ฑ์Šค => ์ตœ๋นˆ๊ฐ’

 

 

 ๐Ÿ’ฌ ์ตœ๋นˆ๊ฐ’(ๆœ€้ ปๅ€ผ, mode)์€ ์ฃผ์–ด์ง„ ๋ฐ์ดํ„ฐ ์„ธํŠธ์—์„œ ๊ฐ€์žฅ ์ž์ฃผ ๋‚˜ํƒ€๋‚˜๋Š” ๊ฐ’์„ ์˜๋ฏธํ•ฉ๋‹ˆ๋‹ค.

class Solution {
    public int solution(int[] array) {
        
        int [] arr = new int [1000];
        
        int max = 0 ;
        int cnt = 0;
        
        for (int i = 0; i < array.length; i++){ 
            arr[array[i]] ++; 
        }
        
        for (int i = 0; i < arr.length; i++){ // arr ๋ฐฉ ๊ฐ’ == i ๊ฐ’
              if (max < arr[i]){
                  max = arr[i]; // ๊ฐœ์ˆ˜ (์ตœ๋Œ€๊ฐ’)
                  cnt = i; // ์ตœ๋นˆ๊ฐ’
              }else if (max == arr[i]){
                  cnt = -1;
              }
        }

        return cnt;
    }
}

 

 

 

[2 ์‹คํŒจ]   ์ „์ฒด์ ์ธ ํ๋ฆ„์€ ์ดํ•ดํ–ˆ๋Š”๋ฐ ์ฝ”๋“œ ์ž‘์„ฑ์ด ํž˜๋“ค์—ˆ๋‹ค..

class Solution {
    public int solution(int[] array) {
        
        int [] arr = new int [1000];
        
        int max = 0 ;
        int cnt = 0;
        //arr = {0,1,1,3,1}
        for (int i = 0; i < array.length; i++){ 
            arr[array[i]] ++; //๋ฐฉ์— ๋Œ€์‘ํ•ด์„œ ๊ฐ’ ๋„ฃ๊ธฐ 0
        }
        for (int i = 0; i < arr.length; i++){ // arr ๋ฐฉ ๊ฐ’ == i ๊ฐ’
              if (max < arr[i]){
                  max = i;
                  cnt = i;
              }

        }
        int cnt2 = 0;
          for (int i = 0; i < arr.length; i++){ // arr ๋ฐฉ ๊ฐ’ == i ๊ฐ’
              if (arr[i] == cnt){
                  cnt2++;
              }
    
        }
        if (cnt2 > 1){
            max = -1;
        }
        
        
        return max;
    }
}

 

 

[1 ์‹คํŒจ]  ํ…Œ์ŠคํŠธ ์ผ€์ด์Šค๋Š” ๋งž์•˜์ง€๋งŒ .... ์‹ค์ œ ํ…Œ์ŠคํŠธ๋Š” ๋ช‡๊ฐœ๋นผ๊ณ  ๋‹ค ํ‹€๋ ธ๋‹ค

์ผ๋‹จ ์ตœ๋นˆ๊ฐ’ ๋™์‹œ์— ๋‚˜์˜ค๋Š” ๊ฒฝ์šฐ๋ถ€ํ„ฐ ์ฒ˜๋ฆฌํ•˜๋Š”๊ฒŒ ์ „์ฒด์ ์œผ๋กœ ์ž˜๋ชป๋œ๋“ฏ 

class Solution {
    public int solution(int[] array) {
        int [] arr = new int [array.length+1];
        // ๋ฐฐ์—ด ๋Œ๋ ค๊ฐ€๋ฉด์„œ ํ•ด๋‹น ๊ฐ’ ++
        
        //arr 
        for (int i = 0; i < array.length; i++){ 
                arr[array[i]-1] ++;
        }
        
        //  ๋ฐฐ์—ด ์•ˆ์— ์ธ๋ฑ์Šค์— ๋Œ€์นญํ•ด์„œ ๊ฐ’ ๋ˆ„์ ๋จ -> ์ธ๋ฑ์Šค๊ฐ’
        
        int max = 0 ;
        int cnt = 0;
        for (int i = 0; i < arr.length; i++){ // arr ๋ฐฐ์—ด ๊ฐ’
            if ( max < arr[i] ){       
                max = arr[i];
            }
            if ( max == arr[i] ){
                cnt ++;
            } 
        }
        if (cnt % 2 == 0){
                max = -1;
        }
        
        return max;
    }
}