반응형

지난달 신시계 그룹의 신세계아이앤씨에서 개발/운영 업무를 뽑는 공고가 있어서 지원했고,
경력기술서와 경험이 마음에 드셨는지 서류전형에 통과했고, 코딩테스트를 보았습니다.


채용 절차는 서류전형 - 코딩테스트 -1차면접 - 2차면접 순으로 진행되었으며, 코딩테스트 후 3일후에 합격통보와 면접 제의를 받았습니다. 다른 분들은 2~3주까지도 걸린다고 했는데, 이번엔 결과가 빨리 나온 편인것 같습니다.

서류 전형

다른 대기업들과 비슷한 채용 사이트(career)를 사용하며, 구성도 거의 비슷해서 특별한 건 없었습니다.
기본정보 / 학력,자격증 / 경력 / 경력기술서 등등 작성하며, 퇴직 사유가 그나마 생각하기에 오래 걸리는 문항이었습니다

마지막 페이지는 자기소개서로 크게 3가지 질문이었습니다. 지원동기, 차별화된 능력과 경험, 자유양식(어필) 이렇게 구성되어 있었던것 같아요

코딩테스트

코딩테스트는 정해진 시간에 접속해서 풀었던것 같아요
사이트 : TestDome
특징 : 모든 지문이 영어
구성 : 10문제 (SQL 7문제 / Java 3문제)
방식 : 1문제당 제한시간내에 풀어서 제출하며, 한번 넘어가면 돌아올 수 없음
난이도 : 쉬움 (SQL도 경력에서 DB를 다뤘다면, 시간이 넉넉하고, JAVA 문제는 프로그래머스 1~1.5?)
특징 : 시간과의 싸움 (시간이 빠듯하다는 평이 많음)
특징2 : JAVA문제는 DFS, DP, 그리디 이런 알고리즘이 아니라 객체지향 관점에서 JAVA를 활용하는 방식에 대한 문제

후기

10문제중 9문제 풀었고, 1문제는 특정 케이스에 실패했는데. 운이 좋게 합격했네요
테스트 3일 후에 합격통보와 면접 일정에 관련된 안내를 받았습니다.
참고로 1차면접은 화상 면접이라고 하네요

반응형
반응형

문제 설명

자연수 n이 매개변수로 주어집니다. n을 x로 나눈 나머지가 1이 되도록 하는 가장 작은 자연수 x를 return 하도록 solution 함수를 완성해주세요. 답이 항상 존재함은 증명될 수 있습니다.

문제

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

나의 풀이

import java.util.stream.IntStream;

public class NumberOfRemainingOne {

    public static void main(String[] args) {
        int n = 12;
        solution(n);
    }

    public static int solution(int n) {
        int answer = 0;
        while(true){
            if(n % ++answer == 1) break;
        }
        return answer;
    }
}

접근

별 다른 로직이 필요 없어 보이고, 역시 가장 단순하지만 기본적인 접근으로 시작 (시작과 끝 숫자를 잘못 정했지만..)

문제 풀이 컨셉은 다들 비슷했고, 나는 끝을 알수 없기에 while문을 적었으나, answer < n 으로 조건을 걸고, 시작은 2부터 했으면 더욱 깔끔한 코드일듯 하다

다른 사람의 풀이

    // Stream 을 활용한 다른사람의 풀이
    public static int solution(int n) {
        return IntStream.range(2,n).filter(i -> n % i == 1).findFirst().orElse(0);
    }

오늘도 Stream 한스푼! 일단 성능은 차치하고, 쓰는 법이나 익힐겸 적어보았다.
IntStream으로 2부터n까지 범위를 주되, filter로 조건을 걸어서 나머지가 1인 숫자, 그중에 첫번째를 찾는 로직

느낀점

  • 이번 문제는 딱히...없는듯
반응형
반응형

출처 : https://programmers.co.kr/learn/courses/30/lessons/77884?language=java 

 

문제 설명

두 정수 left와 right가 매개변수로 주어집니다. left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 하도록 solution 함수를 완성해주세요.

 

나의 풀이

    public int solution(int left, int right) {
        int answer = 0;

        for(int i=left; i<=right; i++){
            if(Math.ceil(Math.sqrt(i)) == Math.floor(Math.sqrt(i))){
                answer -= i;
            }else{
                answer += i;
            }

        }
        return answer;
    }

접근

(수학적으로 생각해보면) 약수의 개수가 홀수라면 소수이다.

따라서 해당 숫자의 제곱근이 자연수라면, 약수의 개수가 홀수개 이고, 그럴 경우에 값을 빼주고

나머지 숫자는 더하도록 구상

다른 사람의 풀이

    public int solution(int left, int right) {
        int sum = 0;
        for (int i = left; i <= right; i++) {
            sum += i * ((countDenominators(i) % 2 == 0) ? 1 : -1);
        }
        return sum;
    }
    private int countDenominators(int num) {
        int count = 0;
        for (int i = 1; i <= num; i++) if (num % i == 0) count++;
        return count;
    }

오랜만에 나의 풀이가 꽤 좋은 평가를 받는 축이었다.

대부분은 중첩 for문을 사용해서 직접 해당수의 약수를 직접 구해서 판단하는 로직이었다.

느낀점

  • 도메인에 대한 지식의 중요성 : 해당 분야에 대해 알고 있다면, 생각보다 빠르고 쉬운 풀이를 알 수 있다
  • 자연수(정수)를 판단하는게 의외로 잘 생각이 나지 않아 올림/내림을 사용했는데 좋은 방법이 있다
    i % Math.sqrt(i) == 0

 

반응형
반응형

문제

본문 : https://programmers.co.kr/learn/courses/30/lessons/77484

로또 6/45(이하 '로또'로 표기)는 1부터 45까지의 숫자 중 6개를 찍어서 맞히는 대표적인 복권입니다. 아래는 로또의 순위를 정하는 방식입니다. 1

순위당첨 내용

1 6개 번호가 모두 일치
2 5개 번호가 일치
3 4개 번호가 일치
4 3개 번호가 일치
5 2개 번호가 일치
6(낙첨) 그 외

로또를 구매한 민우는 당첨 번호 발표일을 학수고대하고 있었습니다. 하지만, 민우의 동생이 로또에 낙서를 하여, 일부 번호를 알아볼 수 없게 되었습니다. 당첨 번호 발표 후, 민우는 자신이 구매했던 로또로 당첨이 가능했던 최고 순위와 최저 순위를 알아보고 싶어 졌습니다.
알아볼 수 없는 번호를 0으로 표기하기로 하고, 민우가 구매한 로또 번호 6개가 44, 1, 0, 0, 31 25라고 가정해보겠습니다. 당첨 번호 6개가 31, 10, 45, 1, 6, 19라면, 당첨 가능한 최고 순위와 최저 순위의 한 예는 아래와 같습니다.

당첨 번호3110451619결과

최고 순위 번호 31 0→10 44 1 0→6 25 4개 번호 일치, 3등
최저 순위 번호 31 0→11 44 1 0→7 25 2개 번호 일치, 5등
  • 순서와 상관없이, 구매한 로또에 당첨 번호와 일치하는 번호가 있으면 맞힌 걸로 인정됩니다.
  • 알아볼 수 없는 두 개의 번호를 각각 10, 6이라고 가정하면 3등에 당첨될 수 있습니다.
    • 3등을 만드는 다른 방법들도 존재합니다. 하지만, 2등 이상으로 만드는 것은 불가능합니다.
  • 알아볼 수 없는 두 개의 번호를 각각 11, 7이라고 가정하면 5등에 당첨될 수 있습니다.
    • 5등을 만드는 다른 방법들도 존재합니다. 하지만, 6등(낙첨)으로 만드는 것은 불가능합니다.

민우가 구매한 로또 번호를 담은 배열 lottos, 당첨 번호를 담은 배열 win_nums가 매개변수로 주어집니다. 이때, 당첨 가능한 최고 순위와 최저 순위를 차례대로 배열에 담아서 return 하도록 solution 함수를 완성해주세요.

 

 

 

 

나의 풀이

class Solution {
    public int[] solution(int[] lottos, int[] win_nums) {
        int[] answer = new int[2];
        int zeroCount = 0;
        int hit = 0;
        
        for(int lotto : lottos){
            if(lotto == 0){
                zeroCount++;
            }else{
                for(int winNum : win_nums){
                    if(lotto == winNum){
                        hit++;
                        break;
                    }
                }
                
            }
        }
        
        answer[1] = 7-hit;
        answer[0] = 7-(hit+zeroCount);
        if(hit == 0) answer[1] = 6;
        if(hit+zeroCount == 0) answer[0] = 6;
        return answer;
    }
}

나의 풀이법

가장 기본적인 접근을 했다.

arrary가 2개이니까 2개의 for문을 이용해 비교하면서, 처리하는 로직을 생각했다.

후에 리팩토링은 더 필요하지만,

lotto ==0 인 경우의 처리와 break문을 통해 조금이나마 성능을 향상 시킬수 있을것이라 생각했다.

가장 지저분한게 생각한 건, 모든 로직을 끝낸후, 단순 결과 return을 위해 5줄이나 소비한것이다.

밑에 Math를 생각했더라면 그나마 만족했을듯

 

다른 사람의 풀이법

import java.util.Arrays;
import java.util.stream.LongStream;

class Solution {
    public int[] solution(int[] lottos, int[] winNums) {
        return LongStream.of(
                (lottos.length + 1) - Arrays.stream(lottos).filter(l -> Arrays.stream(winNums).anyMatch(w -> w == l) || l == 0).count(),
                (lottos.length + 1) - Arrays.stream(lottos).filter(l -> Arrays.stream(winNums).anyMatch(w -> w == l)).count()
        )
                .mapToInt(op -> (int) (op > 6 ? op - 1 : op))
                .toArray();
    }
}

 

느낀점

대체로 가장 기본적인 문제 접근 방식은 나와 비슷한 듯 하다.

다른 사람의 풀이를 보고 배울점이 있다면

  • 코드 라인을 혁신적으로 줄이는 lamda,stream 을 이용하는 경우
    가독성이 떨어지고, 심지어 성능이 떨어지는 경우도 있다 (= 짧은 코드가 항상 최선은 아닐 수 있다)
    하지만 방법을 알아두면, 또 다른 적절한 기회가 생길것
  • 2중 for문 대신 적절한 자료구조(map,set)를 이용하면 1개의 for문을 save할 수 있다
        for(int winNum : win_nums) {
            if(map.containsKey(winNum)) sameCount++;
        }
  • 기본 메소드(Math)를 이용하면, 나의 풀이 맨 아래 5줄을 1줄로 save 할 수 있다. (적절한 메소드)
{Math.min(7 - max, 6), Math.min(7 - min, 6)};
반응형
반응형

문제 설명

프로그래머스 모바일은 개인정보 보호를 위해 고지서를 보낼 때 고객들의 전화번호의 일부를 가립니다.
전화번호가 문자열 phone_number로 주어졌을 때, 전화번호의 뒷 4자리를 제외한 나머지 숫자를 전부 *으로 가린 문자열을 리턴하는 함수, solution을 완성해주세요.

제한 조건

  • s는 길이 4 이상, 20이하인 문자열입니다.

나의 풀이

function solution(phone_number) {
    var answer = '';
    for(var i=0; i<phone_number.length-4; i++){
        answer += '*';
    }
    answer += phone_number.substr(-4);
    return answer;
}

 

  1. loop를 이용한 * 출력
  2. substr을 이용한 문자열 자르기

다른 사람의 풀이

정규식을 이용한다면 1줄컷 가능

반응형

+ Recent posts