14일차 - 알고리즘 코드카타

2024. 8. 1. 19:16·Java & Spring/코딩테스트

- 회고

64. 체육복 https://school.programmers.co.kr/learn/courses/30/lessons/42862

 

프로그래머스

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

programmers.co.kr

import java.util.*;
class Solution {
    public int solution(int n, int[] lost, int[] reserve) {
        Arrays.sort(lost);
        Arrays.sort(reserve);
        
        List<Integer> reserveLi = new ArrayList<>();
        for(int i = 0; i < reserve.length; i++){
            reserveLi.add(reserve[i]);
        }
        
        int cnt = n - lost.length;
        
        for(int i = 0; i < lost.length; i++){
            if(reserveLi.contains(lost[i])){
                reserveLi.set(reserveLi.indexOf(lost[i]), -1);
                lost[i] = -1;
                cnt++;
            }
        }
        
        for(int l : lost){
            if(reserveLi.contains(l - 1)){
                reserveLi.set(reserveLi.indexOf(l - 1), -1);
                cnt++;
            }else if(reserveLi.contains(l + 1)){
                reserveLi.set(reserveLi.indexOf(l + 1), -1);
                cnt++;
            }
        }
        return cnt;
    }
}

 

- 풀이과정

  1. 처음에 문제를 정확히 읽지않아 여분이있는사람 잃어버릴수도 있는 경우를 누락
  2. contain함수를 쓰기위해 빌려줄 수 있는 사람의 List를 생성
  3. 처음 체육이 가능한 사람의 수는 총 학생 수(n) - 잃어버린 학생 수(lost.length)로 cnt를 잡고
  4. 우선 1.의 경우를 비교대상에서 제외시키고 cnt++
  5. lost 배열을 순회하며 -1, +1의 경우 확인하여 cnt++

- 진행

일자 완료 번호
24.07.16 1~20
24.07.17 21~35
24.07.18 36~42
24.07.19 43~47
24.07.22 48~50
24.07.23 51~55
24.07.24 56~57
24.07.25 58
24.07.26 59~60
24.07.29 61
24.07.30 62
24.07.31 63
24.08.01 64

 

'Java & Spring > 코딩테스트' 카테고리의 다른 글

16일차 - 알고리즘 코드카타  (0) 2024.08.06
15일차 - 알고리즘 코드카타  (1) 2024.08.05
13일차 - 알고리즘 코드카타(시간초과)  (0) 2024.07.31
12일차 - 알고리즘 코드카타(실패)  (0) 2024.07.31
11일차 - 알고리즘 코드카타  (1) 2024.07.29
'Java & Spring/코딩테스트' 카테고리의 다른 글
  • 16일차 - 알고리즘 코드카타
  • 15일차 - 알고리즘 코드카타
  • 13일차 - 알고리즘 코드카타(시간초과)
  • 12일차 - 알고리즘 코드카타(실패)
DJ.Kang
DJ.Kang
백엔드 개발 기록 블로그
  • DJ.Kang
    DJ Hello World
    DJ.Kang
  • 전체
    오늘
    어제
    • 분류 전체보기 N
      • 이론공부 N
        • 정보처리기사 N
      • 시스템설계
      • Java & Spring
        • TIL
        • 트러블슈팅
        • 고도화
        • 알고리즘
        • 코딩테스트
        • Java
        • Spring
        • Thymeleaf
      • 프로젝트
        • coin-trading
        • 트러블슈팅
      • Docker
      • DB
      • AWS
      • CI-CD
      • 웹
      • git & github
      • 구인공고분석
  • 블로그 메뉴

    • 홈
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    java two-pointer
    프로그래머스 java 기초 트레이닝
    java super
    java 에라토스테네스의 체
    java 메서드
    프로그래머스 java 기초트레이닝
    Java this
    java 세수의합
    java enhance switch
    데이터 타입
    java 유클리드 호제법
    java 멤버
    데이터 크기
    java 제어자
    자료구조
    Java 생성자
    java
    java기초
    개발로드맵
    java arrays.copyofrnage()
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.1
DJ.Kang
14일차 - 알고리즘 코드카타
상단으로

티스토리툴바