CODE KATA #31

YoungToMaturity·2021년 3월 31일
0

CODE KATA 🧗‍♂️

목록 보기
32/37
post-thumbnail

학급 회장 (해시)

학급 회장을 뽑는데 후보로 기호 A, B, C, D, E 후보가 등록을 했습니다.
투표용지에는 반 학생들이 자기가 선택한 후보의 기호(알파벳)가 쓰여져 있으며 선생님은 그 기호를 발표하고 있습니다.
선생님의 발표가 끝난 후 어떤 기호의 후보가 학급 회장이 되었는지 출력하는 프로그램을 작성하세요. 반드시 한 명의 학급회장이 선출되도록 투표결과가 나왔다고 가정합니다.

나의 풀이

            function solution(s){  
                let answer;
                let a=0,b=0,c=0,d=0,e=0;
                for (let x of s) {
                    if (x==='A') {
                        a++;
                    } else if (x==='B') {
                        b++;
                    } else if (x==='C') {
                        c++;
                    } else if (x==='D') {
                        d++;
                    } else if (x==='E') {
                        e++;
                    }
                }
                let max = Math.max(a,b,c,d,e);
                if (max===a) answer = "A";
                else if (max===b) answer = "B";
                else if (max===c) answer = "C";
                else if (max===d) answer = "D";
                else if (max===e) answer = "E";
                return answer;
            }

            let str="BACBACCACCBDEDE";
            console.log(solution(str));

정답 풀이

            function solution(s){  
                let answer;
                let sH = new Map();
                for(let x of s){
                    if(sH.has(x)) sH.set(x, sH.get(x)+1);
                    else sH.set(x, 1);
                }
                let max=Number.MIN_SAFE_INTEGER;
                for(let [key, val] of sH){
                    if(val>max){
                        max=val;
                        answer=key;
                    }
                }
                return answer;
            }

            let str="BACBACCACCBDEDE";
            console.log(solution(str));

객체 Map

정답 풀이와 나의 풀이간에 전체적인 풀이의 틀은 같다고 생각한다. 하지만, 정답의 경우는 sH라는 Map 객체를 통해 각각의 후보(A,B,C,D,E)를 key로서, 각 후보에 대한 표를 Value로서 사용하여 더 가독성이 좋게 코드를 처리하였다.

profile
iOS Developer

0개의 댓글