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

    • 홈
  • 링크

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

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

티스토리툴바