전체 글

전체 글

    자바(Java) 알고리즘 문제풀이 인접행렬 경로탐색 [인프런 / 모든 조합 유형]

    강의의 문제를 가져왔기 때문에 밝힙니다 ! 임의로 추가, 수정, 삭제한 내용들이 있으니 정확한 이해를 위해서는 강의를 구매하시는 것을 추천드립니다 😅 출처 : 자바(Java) 알고리즘 문제풀이 : 코딩테스트 대비 (인프런 강의) 풀이 코드 인접 행렬로 그래프를 표현해서 풀이하는 방법과 인접 리스트로 그래프를 표현해 풀이하는 방법이 있다. 먼저 인접 행렬로 풀이하자면, 2차원 배열을 만들고 간선의 갯수만큼 반복문을 설정한 뒤 A 노드와 B 노드가 연결되어있다고 가정했을 때 matrix[a][b] = 1 로 배열을 채워주면 된다. 그러고 행을 기준으로 잡고 1로 표시되어 있는 열을 찾으면 되는데 즉, 서로 연결되어있는 노드를 찾아주는 것을 의미한다. 예를 들어, matrix[1][2] = 1 이라면 1번 노..

    자바(Java) 알고리즘 문제풀이 베스트 앨범 [프로그래머스 / Hash]

    문제 설명 스트리밍 사이트에서 장르 별로 가장 많이 재생된 노래를 두 개씩 모아 베스트 앨범을 출시하려 합니다. 노래는 고유 번호로 구분하며, 노래를 수록하는 기준은 다음과 같습니다. 속한 노래가 많이 재생된 장르를 먼저 수록합니다. 장르 내에서 많이 재생된 노래를 먼저 수록합니다. 장르 내에서 재생 횟수가 같은 노래 중에서는 고유 번호가 낮은 노래를 먼저 수록합니다. 노래의 장르를 나타내는 문자열 배열 genres와 노래별 재생 횟수를 나타내는 정수 배열 plays가 주어질 때, 베스트 앨범에 들어갈 노래의 고유 번호를 순서대로 return 하도록 solution 함수를 완성하세요. 제한사항 genres[i]는 고유번호가 i인 노래의 장르입니다. plays[i]는 고유번호가 i인 노래가 재생된 횟수입니..

    자바(Java) 알고리즘 문제풀이 전화번호 목록 [프로그래머스 / Hash]

    문제 설명 전화번호부에 적힌 전화번호 중, 한 번호가 다른 번호의 접두어인 경우가 있는지 확인하려 합니다. 전화번호가 다음과 같을 경우, 구조대 전화번호는 영석이의 전화번호의 접두사입니다. 구조대 : 119 박준영 : 97 674 223 지영석 : 11 9552 4421 전화번호부에 적힌 전화번호를 담은 배열 phone_book 이 solution 함수의 매개변수로 주어질 때, 어떤 번호가 다른 번호의 접두어인 경우가 있으면 false를 그렇지 않으면 true를 return 하도록 solution 함수를 작성해주세요. 제한사항 phone_book의 길이는 1 이상 1,000,000 이하입니다. 각 전화번호의 길이는 1 이상 20 이하입니다. 같은 전화번호가 중복해서 들어있지 않습니다. 입출력 예시 pho..

    자바(Java) 알고리즘 문제풀이 완주하지 못한 선수 [프로그래머스 / Hash]

    문제 설명 수많은 마라톤 선수들이 마라톤에 참여하였습니다. 단 한 명의 선수를 제외하고는 모든 선수가 마라톤을 완주하였습니다. 마라톤에 참여한 선수들의 이름이 담긴 배열 participant와 완주한 선수들의 이름이 담긴 배열 completion이 주어질 때, 완주하지 못한 선수의 이름을 return 하도록 solution 함수를 작성해주세요. 제한사항 마라톤 경기에 참여한 선수의 수는 1명 이상 100,000명 이하입니다. completion의 길이는 participant의 길이보다 1 작습니다. 참가자의 이름은 1개 이상 20개 이하의 알파벳 소문자로 이루어져 있습니다. 참가자 중에는 동명이인이 있을 수 있습니다. 입출력 예시 participant completionreturn result ["leo..

    자바(Java) 알고리즘 문제풀이 폰켓몬 [프로그래머스 / Hash]

    문제 설명 당신은 폰켓몬을 잡기 위한 오랜 여행 끝에, 홍 박사님의 연구실에 도착했습니다. 홍 박사님은 당신에게 자신의 연구실에 있는 총 N 마리의 폰켓몬 중에서 N/2마리를 가져가도 좋다고 했습니다. 홍 박사님 연구실의 폰켓몬은 종류에 따라 번호를 붙여 구분합니다. 따라서 같은 종류의 폰켓몬은 같은 번호를 가지고 있습니다. 예를 들어 연구실에 총 4마리의 폰켓몬이 있고, 각 폰켓몬의 종류 번호가 [3번, 1번, 2번, 3번]이라면 이는 3번 폰켓몬 두 마리, 1번 폰켓몬 한 마리, 2번 폰켓몬 한 마리가 있음을 나타냅니다. 이때, 4마리의 폰켓몬 중 2마리를 고르는 방법은 다음과 같이 6가지가 있습니다. 첫 번째(3번), 두 번째(1번) 폰켓몬을 선택 첫 번째(3번), 세 번째(2번) 폰켓몬을 선택 첫..

    2022.08.23 (화요일) ~ 2022.08.26 (금요일) 주간 및 일일 학습계획

    주간목표 2022.08.23 ~ 2022.08.26 컨디션 관리 알고리즘 모의고사 진행 (화요일) 프로그래머스 코딩테스트 고득점 Kit Hash, 정렬 모두 풀이 하루에 꼭 목표한 두 문제 풀이 Issue Traker 리팩토링 2022 인프콘 참석 일일목표 2022.08.23 (화요일) 프로그래머스 Hash 문제 풀이 폰켓몬 완주하지 못한 선수 전화번호 목록 위장 일일목표 2022.08.24 (수요일) JPA 프록시와 연관관계 복습 프로그래머스 Hash 문제 풀이 베스트 앨범 프로그래머스 정렬 풀이 시작 K번째 수 가장 큰 수 Issue Tracker 리팩토링 시작 Issue Detail Read API 호출 시 사용자 Image 도 같이 Response 하도록 변경 Client -> Server Iss..

    2022 프로그래머스 코딩테스트 모의고사 1 (1, 2, 3번 문제)

    어제 프로그래머스에서 진행하는 코딩테스트 모의고사가 있다고 듣고 모의고사 1 문제를 풀었다. 1 ~ 3 번 문제는 어찌저찌해서 풀었는데, 4 번 문제는 손을 대질 못하겠어서 넘김 .. 🥲 감도 안잡히더라 어떻게 푸는 걸까 ㅋㅋ?? 한 문제당 만점이 100점이고, 총 300점이 나왔는데 상위 58% 정도로 나와서 굉장히 놀랬다 ;; 일단 풀어낸 1 ~ 3 번 문제에 대해 간단하게 기록하려고 한다. 1 번 문제 설명 💡 정수로 이루어진 String Type 의 X, Y를 입력받습니다. X 와 Y 각 인덱스 마다 같은 숫자를 짝을 짓는데, 이를 짝궁이라 합니다. 예를들어, X = 1120, Y = 2134 라면, 짝궁은 "21" 이 됩니다. 짝이 지어지는 숫자들로 만들 수 있는 가장 큰 수를 리턴하는 프로그램..

    자바(Java) 알고리즘 문제풀이 최소 스패닝 트리[백준 / 크루스칼(그리디)]

    https://www.acmicpc.net/problem/1197 1197번: 최소 스패닝 트리 첫째 줄에 정점의 개수 V(1 ≤ V ≤ 10,000)와 간선의 개수 E(1 ≤ E ≤ 100,000)가 주어진다. 다음 E개의 줄에는 각 간선에 대한 정보를 나타내는 세 정수 A, B, C가 주어진다. 이는 A번 정점과 B번 정점이 www.acmicpc.net 풀이 코드 이 문제는 최소 신장트리를 구하는 문제인데, 크루스칼 알고리즘을 사용하면 해결되는 문제이다. 크루스칼 알고리즘이란, 그래프 내 모든 정점들을 가장 적은 비용으로 연결하기 위해 사용된다. 쉽게 말해 그래프를 회로가 없는 트리로 만들면 되는 것. 그래프 내의 모든 정점들 중, 가장 적은 비용을 가진 간선부터 연결을 시작하고 연결하기 전에 해당 ..

    자바(Java) 알고리즘 문제풀이 절댓값 힙[백준 / 우선순위 큐]

    11286번: 절댓값 힙 첫째 줄에 연산의 개수 N(1≤N≤100,000)이 주어진다. 다음 N개의 줄에는 연산에 대한 정보를 나타내는 정수 x가 주어진다. 만약 x가 0이 아니라면 배열에 x라는 값을 넣는(추가하는) 연산이고, x가 0 www.acmicpc.net 풀이 코드 우선순위 큐를 연습할 수 있는 문제로 PriorityQueue 를 사용해서 오름차순 출력을 뽑아내는 문제이다. 절댓값이 같은 경우에서 정렬의 재정의가 필요한데, PriorityQueue 의 인자로 Comparator 를 사용할 수 있으므로 활용하면 된다. 먼저 Math.abs() 메서드를 통해 절댓값을 구하고, 오름차순에 알맞게 정의를 해준다. abs1 이 abs2 보다 큰 경우 양수 즉, 자리바뀜이 일어나고, 음수일 때는 자리바뀜..

    2022.08.15 (월요일) ~ 2022.08.20 (토요일) 주간 및 일일 학습계획

    주간목표 2022.08.15 ~ 2022.08.20 컨디션 관리 알고리즘 스터디 진행 (수요일) 그리디 알고리즘, Priority Queue, Union & Find 한번 더 복습 CS 교재 구매 JPA 기본편 강의 다시 달리기 일일목표 2022.08.15 (월요일) Priority Queue 학습 및 문제 풀이 Union & Find 학습 및 문제 풀이 일일목표 2022.08.16 (화요일) Priority Queue 복습 Union & Find 복습 (크루스칼 알고리즘 / 최소 신장트리 알고리즘) JPA 고급 매핑까지 강의 시청 밀리가 전달한 내용 Issue Tracker 에 적용 (21:30 시작) 일일목표 2022.08.17 (수요일) 알고리즘 그리디 Section 모든 문제 복습 알고리즘 스터디..