https://school.programmers.co.kr/learn/courses/30/lessons/72412 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 2021 KAKAO BLIND RECRUITMENT Level 2 문제다. info의 각 값들을 2차원 배열에 넣고, query를 탐색하며 info를 하나하나 비교하는 코드를 작성했다. 정확성은 맞는데 효율성 테스트를 틀려서 문제 조건을 다시 보니, info 크기는 최대 50000이고 query 크기는 최대 100000이기 때문에 시간 초과가 날 수 밖에 없었다. https://coding-gra..
https://school.programmers.co.kr/learn/courses/30/lessons/72410 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 2021 KAKAO BLIND RECRUITMENT Level 1 문제다. 정규 표현식을 잘 몰라서 지저분하게 코드를 작성했다. Level 1이기 때문에 딱히 설명할 것 없이 코드를 보면 이해가 된다. for문으로 하나하나 다 탐색해 숫자, 영어, -, _, . 이외의 문자가 들어올 경우 일단 *로 치환하고, 나중에 String의 replaceAll을 통해서 *를 ""(빈 문자열)로 없앴다. St..
https://school.programmers.co.kr/learn/courses/30/lessons/92342 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 2022 KAKAO BLIND RECRUITMENT Level 2 문제다. info가 11, n의 최대가 10이므로 가장 먼저 백트래킹 DFS를 떠올렸다. DFS가 진행될수록 result에 화살을 쏜 개수를 저장한다. 라이언이 무조건 이겨야하는 경우만 고려하면 되므로, 어피치가 쏜 화살보다 한개 더 많은 화살을 쏜다고 가정했다. 라이언이 화살을 쏠 때마다 cnt를 감소시켜서, 남은 화살의 개수를 ..
https://school.programmers.co.kr/learn/courses/30/lessons/92341 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 2022 KAKAO BLIND RECRUITMENT의 Level 2 문제다. 특별히 고려해야 할 것 없이 문제에서 요구하는 대로 구현하면 된다. TreeMap에 차 번호를 key값으로, time을 담은 ArrayList를 value로 저장했다. 그리고 map의 value를 하나씩 꺼내 시간을 계산했다. value인 ArrayList의 size가 홀수라면, 입차 후 출차 내역이 없는 것이므로 시간을..
https://school.programmers.co.kr/learn/courses/30/lessons/92335 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 2022 KAKAO BLIND RECRUITMENT Level 2 문제다. 처음엔 조건에 맞는 소수라고 하니 꽤나 복잡해보였다. 주어진 숫자를 k진수로 변환 후, 0을 기준으로 잘라 소수인지 판별하면 된다. 예시를 보면 0을 기준으로 자르기만 하면 간단한 문제임을 알 수 있다. 437674 -> 211020101011 -> 211, 2, 1, 1, 11 -> 211, 2, 11 -> 3개 처음엔 ..
https://school.programmers.co.kr/learn/courses/30/lessons/92334 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 2022 KAKAO BLIND RECRUITMENT의 Level 1 문제다. 사용자별 신고 여부를 저장할 boolean 2차원 배열 report_yn을 생성했다. 만약 report_yn[i][j]가 true라면 i번째의 사용자가 j번째의 사용자를 신고한 것이다. HashMap map = new HashMap(); for(int i=0;i
https://school.programmers.co.kr/learn/courses/30/lessons/42747 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 프로그래머스 코딩테스트 고득점 Kit의 정렬 Level 2 문제다. 만약에 [1, 0, 0] 이 입력으로 들어온다면 1편의 논문이 1회 이상 인용되었으므로 1이 반환될 것이다. 또한 [5, 4, 3, 1, 1] 이 입력으로 들어온다면 3편의 논문이 3회 이상 인용되었으므로 3이 반환될 것이다. 여기서 규칙을 찾을 수 있다. 논문을 내림차순으로 정렬하고, 배열을 앞에부터 탐색한다. 앞에 원소가 1회..
https://school.programmers.co.kr/learn/courses/30/lessons/42746 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 프로그래머스 코딩테스트 고득점 Kit의 정렬 Level 2 문제다. numbers를 문자열로 변환해 배열에 넣고,그 배열을 내림차순으로 정렬한다. 정렬한 순서대로 이어붙여 return하면 된다. 문자열을 이어붙이려는 경우 String의 +=보다 StringBuilder의 append를 사용하는게 훨씬 효율적이다. (String은 +=할 때마다 새로운 주소의 객체를 생성하기 때문) 또한 입력으로 [..