MapleStory Finger Point

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

ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค - java ๋ฌธ์ž์—ด ๋ฌถ๊ธฐ

HYEJU01 2024. 5. 9. 12:24

 ๐Ÿ’ก ๋ฐฐ์—ด์— ์žˆ๋Š” ๋ฌธ์ž์—ด ์ค‘ ๋ฌธ์ž์—ด ๊ธธ์ด๊ฐ€ ๊ฐ™์€ ๋ฌธ์ž์—ด๋“ค ๋ผ๋ฆฌ ๋ฌถ์—ˆ์„ ๋•Œ

๊ทธ ๊ฐœ์ˆ˜๊ฐ€ ๊ฐ€์žฅ ๋งŽ์€ ์ง‘ํ•ฉ์˜ ๋ฌธ์ž์—ด ๊ธธ์ด๋ฅผ ๋ฆฌํ„ดํ•œ๋‹ค.

 

๐Ÿฅน ์ด ๋ฌธ์ œ๋ฅผ ํ‘ธ๋Š”๋ฐ ์ ‘๊ทผ๋ฐฉ๋ฒ•์„ ๊ณ„์† ๋ฐ”๊พธ๋ฉด์„œ ๊ณ ์ƒ์„ ํ–ˆ๋‹ค..ใ… 

 

 

 

1) ๋ฌธ์ž์—ด ์ตœ๋Œ€ ๊ธธ์ด๋งŒํผ์˜ ๋ฐฐ์—ด์„ ์ƒ์„ฑํ•ด์ค€๋‹ค.

์ด์ œ ์ด ๋ฐฐ์—ด์€ 0~29 (1~30) ๊ฐ๊ฐ ๋ฐฐ์—ด ์ธ๋ฑ์Šค = ๋ฌธ์ž์—ด ๊ธธ์ด์— ํ•ด๋‹นํ•˜๋Š”

๋ฌธ์ž์—ด์ด ์žˆ์œผ๋ฉด 1์”ฉ ์นด์šดํŠธ ๋œ๋‹ค.

 

2) 1~30 == ๋ฌธ์ž์—ด ๊ธธ์ด๋ฅผ ๋น„๊ตํ•ด์ฃผ๋ฉด์„œ ๋ฐฐ์—ด๊ฐ’์— ์นด์šดํŒ…ํ•ด์ค€๋‹ค.

(์ด๋•Œ ๋ฐฐ์—ด์€ 0๋ถ€ํ„ฐ ์‹œ์ž‘ํ•˜๋ฏ€๋กœ j-1 ํ•ด์ค˜์•ผํ•œ๋‹ค)

 

3) ๋ฌธ์ž์—ด ๊ธธ์ด๊ฐ’์ด ๊ฐ™์€ ๊ฐ’์˜ ๊ฐœ์ˆ˜๊ฐ€ ๋ชจ์—ฌ์žˆ๋Š” ๋ฐฐ์—ด์ด๋ฏ€๋กœ

๋ฐฐ์—ด ์ค‘ ๊ฐ€์žฅ ํฐ ๊ฐ’์„ ๋ฆฌํ„ดํ•ด์ฃผ๋ฉด ๋œ๋‹ค.

 (= ๋ฌธ์ž์—ด ๊ธธ์ด๊ฐ€ ๊ฐ™๊ณ  ์ œ์ผ ๋งŽ์€ ์ง‘ํ•ฉํฌ๊ธฐ์„ ๋ฆฌํ„ดํ•˜๋ผ๊ณ  ํ–ˆ์œผ๋ฏ€๋กœ)

 

 

import java.util.ArrayList;

class Solution {
    public int solution(String[] strArr) {
        int[] arr = new int[30]; // 0 ~ 29
        int answer = 0; 
        
        for (int i = 0; i < strArr.length; i++){ 
            for (int j = 1; j <= 30; j++){ 
                if ( strArr[i].length() == j){ // ๊ธธ์ด๋ฅผ 1~30 ๋น„๊ต
                    arr[j-1]++;  // ์ธ๋ฑ์Šค๋Š” 0๋ถ€ํ„ฐ
                } 
            }
        }
        
        // ์ธ๋ฑ์Šค ๊ฐ’ ์ค‘ ์ ค ํฐ ๊ฐ’ ๊ตฌํ•˜๊ธฐ
        for (int i = 0; i < arr.length; i++){ 
            if(arr[i] > answer){
                answer = arr[i];
            }
        }

        return answer;
    }
}

 

 


์ฒซ๋ฒˆ์งธ ์‹œ๋„ )  2์ฐจ์› ๋ฐฐ์—ด

์ƒ์ƒ์œผ๋ก  1์ฐจ์— ๊ธธ์ด (1~30) , 2์ฐจ์— ๊ธธ์ด๊ฐ€ ๊ฐ™์€ ๋ฌธ์ž์—ด๋“ค์„ ๋„ฃ์–ด๋ณด๋ ค๊ณ ํ–ˆ๋‹ค.

ํ•ด๋ณด๋ ค๊ณ ํ–ˆ๋Š”๋ฐ ๋จธ๋ฆฌ๋งŒ ์•„ํ”„๊ณ  ..... ์ƒ๊ฐํ•ด๋ณด๋‹ˆ 2์ฐจ์› ๋ฐฐ์—ด๊นŒ์ง€ ์‚ฌ์šฉํ•  ์ด์œ ๊ฐ€ ์—†์—ˆ๋‹ค. ใ… ใ… 

 

import java.util.ArrayList;

class Solution {
    public int solution(String[] strArr) {
        ArrayList<ArrayList<String>> arr = new ArrayList<>();
        int answer = 0;
        
        for (int i = 0; i < strArr.length; i++){ // arr ์ˆœํšŒํ•˜๋ฉด์„œ
            for (int j = 1; j <= 30; j++){ // ๋ฌธ์ž์—ด ๊ธธ์ด ๋ณ„๋กœ ๋ฐฐ์—ด์— ์‚ฝ์ž…
                arr.add(Integer.toString(j)); // ๊ธธ์ด๊ฐ’ ๋ฐฐ์—ด[]
                if (strArr.length == j) //  ๊ฐ™์€ ๊ธธ์ด ๋ผ๋ฆฌ ๋ฐฐ์—ด[][]
                    arr.get(i-1).add(strArr[i]); //2์ฐจ์›๋ฐฐ์—ด์— ์‚ฝ์ž…
            }
        }
        int max = 0;
        //๊ธธ์ด๊ฐ€ ๊ฐ™์€ ๋ฌธ์ž์—ด๋“ค , ๊ฐœ์ˆ˜๊ฐ€ ๋งŽ์€ ๊ฒƒ
        for (int i = 0; i < arr.size(); i++){ // ๋ฐฐ์—ด[] ๋งŒํผ
            if (arr.get(i).size() > max) { //๋ฐฐ์—ด[][] ๋น„๊ต
                max = arr.get(i); 
            }    
        }
        return answer;
    }
}

 

 

 


๋‘๋ฒˆ์งธ ์‹œ๋„ ) 1์ฐจ์› ๋ฐฐ์—ด

์ด ๊ฒฝ์šฐ์—๋Š” ๋ฐฐ์—ด์— ๊ธธ์ด ๊ฐ’์„ ์ฐจ๋ก€๋Œ€๋กœ ๋„ฃ์–ด์„œ ๊ทธ ์ค‘ ๊ฐ™์€ ๊ฐ’์„ ์ฐพ๊ณ ?

๊ทธ ๊ฐœ์ˆ˜๊ฐ€ ์ œ์ผ ๋งŽ์€ ๊ฐ’์„ ์ฐพ์•„๋ณด๋ ค๊ณ ํ–ˆ๋‹ค.

๊ทผ๋ฐ ๊ธธ์ด๊ฐ’์„ ์ธ๋ฑ์Šค์™€ ๋งค์นญ์‹œํ‚ค๋ฉด ๋˜๊ธฐ๋•Œ๋ฌธ์— ๊ทธ๋Ÿด ํ•„์š”๊ฐ€ ์—†์—ˆ๋‹ค.

 

import java.util.ArrayList;

class Solution {
    public int solution(String[] strArr) {
        String[] arr = new String [30];
        int answer = 0; // max
        
        for (int i = 0; i < strArr.length; i++){ // 1) arr ์ˆœํšŒํ•˜๋ฉด์„œ
            for (int j = 1; j <= 30; j++){ 
                if (strArr[i].length() == j) 
                    arr[j-1] = strArr[i]; 
            }
        }
        //๊ธธ์ด๊ฐ€ ๊ฐ™์€ ๋ฌธ์ž์—ด๋“ค , ๊ฐœ์ˆ˜๊ฐ€ ๋งŽ์€ ๊ฒƒ
        for (int i = 0; i < arr.length; i++){ // ๋ฐฐ์—ด[] ๋งŒํผ
            if(arr[i].length()> answer){
                answer = arr[i].length();
            }
        }
        
        return answer;
    }
}