mun dev

[COS PRO 1급] 1-9 계단 게임 자바(Java) 본문

알고리즘/COS PRO 1급

[COS PRO 1급] 1-9 계단 게임 자바(Java)

mndev 2023. 11. 25. 16:21

문제링크

 

구름HOME

구름은 클라우드 기술을 이용하여 누구나 코딩을 배우고, 실력을 평가하고, 소프트웨어를 개발할 수 있는 클라우드 소프트웨어 생태계입니다.

www.goorm.io

 

문제유형

한줄 바꾸기 문제

 

문제

class Main {
    public int func(int record){
        if(record == 0) return 1;
        else if(record == 1) return 2;
        return 0;
    }
 
    public int solution(int[] recordA, int[] recordB){
        int cnt = 0;
        for(int i = 0; i < recordA.length; i++){
            if(recordA[i] == recordB[i])
                continue;
            else if(recordA[i] == func(recordB[i]))
                cnt = cnt + 3;
            else 
                cnt = cnt - 1;
        }
        return cnt;
    }
 
public static void main(String[] args) {
        Main sol = new Main();
        int[] recordA = {2,0,0,0,0,0,1,1,0,0};
        int[] recordB = {0,0,0,0,2,2,0,2,2,2};
        int ret = sol.solution(recordA, recordB);
 
        System.out.println("solution 함수의 반환값은 " + ret + " 입니다.");
    }
}

 

문제 풀이

class Main {
    public int func(int record){
        if(record == 0) return 1;
        else if(record == 1) return 2;
        return 0;
    }
 
    public int solution(int[] recordA, int[] recordB){
        int cnt = 0;
        for(int i = 0; i < recordA.length; i++){
            if(recordA[i] == recordB[i] || (recordA[i] != func(recordB[i]) && cnt==0))
                continue;
            else if(recordA[i] == func(recordB[i]))
                cnt = cnt + 3;
            else 
                cnt = cnt - 1;
        }
        return cnt;
    }
 
public static void main(String[] args) {
        Main sol = new Main();
        int[] recordA = {2,0,0,0,0,0,1,1,0,0};
        int[] recordB = {0,0,0,0,2,2,0,2,2,2};
        int ret = sol.solution(recordA, recordB);
 
        System.out.println("solution 함수의 반환값은 " + ret + " 입니다.");
    }
}