java 31

프로그래머스 : 이상한 문자 만들기 (Java)

1. 문제링크 https://programmers.co.kr/learn/courses/30/lessons/12930 코딩테스트 연습 - 이상한 문자 만들기 문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 programmers.co.kr 2. 접근방법 공백을 기준으로 짝수 홀수를 구분지어 대 소문자를 만들어준다 내장되어있는 Character.toUpperCase(), Character.toLowerCase() 를 사용해주자! 3. 코드 class Solution { public String solution(String s) { String answer = ""; cha..

알고리즘 2021.06.16

백준 17485 : 진우의 달 여행 (Large) (Java)

1. 문제링크 https://www.acmicpc.net/problem/17485 17485번: 진우의 달 여행 (Large) 첫줄에 지구와 달 사이 공간을 나타내는 행렬의 크기를 나타내는 N, M (2 ≤ N, M ≤ 1000)이 주어진다. 다음 N줄 동안 각 행렬의 원소 값이 주어진다. 각 행렬의 원소값은 100 이하의 자연수이다. www.acmicpc.net 2. 접근방법 우주선은 3개의 방향으로 나올 수 있다 즉 dp[n][m] 사이즈에서 나올수있는 3가지 방향 [3] 까지 해서 3차원 배열로 생각해주자 제일 오른쪽과 제일 왼쪽은 각 대각선별로 올 수 없다! 이 예외처리를 해주어야 한다!! 중요!! 이것이 다되면 제일 밑에 도착한 값들 중 최소값을 찾아주면 종료~! 3. 코드 import java..

알고리즘 2021.06.09

프로그래머스 : 위장 (Java)

1. 문제링크 https://programmers.co.kr/learn/courses/30/lessons/42578 코딩테스트 연습 - 위장 programmers.co.kr 2. 접근방법 옷을 입는 경우! 와 옷을 안입는 경우를 생각한다면 종류별로 나올 수 있는 수를 생각해보면 된다! a1 b4 c3 라는 종류가 나왓다고 가정하면 a를 안입을수도잇고 b를 안입을수도잇고 c를 안입을수도있따! a2 b5 c4 를 HashMap에 담아서 계산해주면 된다 여기서! 마지막으로 다 안입을 경우인 1을 빼주면 정답~ 3. 코드 import java.util.*; class Solution { public int solution(String[][] clothes) { int answer = 0; HashMap map ..

알고리즘 2021.06.08

프로그래머스 : 카카오 프렌즈 컬러링북 (Java)

1. 문제링크 https://programmers.co.kr/learn/courses/30/lessons/1829 코딩테스트 연습 - 카카오프렌즈 컬러링북 6 4 [[1, 1, 1, 0], [1, 2, 2, 0], [1, 0, 0, 1], [0, 0, 0, 1], [0, 0, 0, 3], [0, 0, 0, 3]] [4, 5] programmers.co.kr 2. 접근방법 picture 배열에서 0을 제외한 나머지 부분은 영역으로 표시된다 사방탐색으로 이어진 영역을 구분하고 0으로 바꾸면서 카운트를 센다 -> 영역 갯수 1 추가 이후 인접한 영역의 갯수를 세서 최종 갯수를 확인해서 가장 많은 영역을 찾는다~ 3. 코드 import java.util.*; class Solution { class Point ..

알고리즘 2021.06.07

SW Expert Academy 3431 : 준환이의 운동관리

1. 문제링크 https://swexpertacademy.com/main/code/problem/problemDetail.do?problemLevel=3&contestProbId=AWE_ZXcqAAMDFAV2&categoryId=AWE_ZXcqAAMDFAV2&categoryType=CODE&problemTitle=&orderBy=PASS_RATE&selectCodeLang=ALL&select-1=3&pageSize=10&pageIndex=1 SW Expert Academy SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요! swexpertacademy.com 2. 접근방법 주어진 문제를 보면 조건이 3가지 경우가 나온다 운동을 덜 했을때 운동을 맞춰서 했을때 운동을 넘치도록 했을때..

알고리즘 2021.06.04

프로그래머스 : 정수 내림차순으로 배치하기 (Java)

1. 문제링크 https://programmers.co.kr/learn/courses/30/lessons/12933 코딩테스트 연습 - 정수 내림차순으로 배치하기 함수 solution은 정수 n을 매개변수로 입력받습니다. n의 각 자릿수를 큰것부터 작은 순으로 정렬한 새로운 정수를 리턴해주세요. 예를들어 n이 118372면 873211을 리턴하면 됩니다. 제한 조건 n은 1이 programmers.co.kr 2. 접근방법 입력값의 길이를 먼저 구하고 난 이후 길이 만큼의 크기의 배열에 담아 준 다음 sort를 사용합니다! 그러면 정렬이 되어있어요~ 그상태로 다시 첫번째 자리부터 더하면서 자리수를 늘려가면 저엉다압~ 3. 코드 import java.util.*; class Solution { public ..

알고리즘 2021.06.04

프로그래머스 : 자연수 뒤집어 배열로 만들기 (Java)

1. 문제링크 https://programmers.co.kr/learn/courses/30/lessons/12932 코딩테스트 연습 - 자연수 뒤집어 배열로 만들기 자연수 n을 뒤집어 각 자리 숫자를 원소로 가지는 배열 형태로 리턴해주세요. 예를들어 n이 12345이면 [5,4,3,2,1]을 리턴합니다. 제한 조건 n은 10,000,000,000이하인 자연수입니다. 입출력 예 n return 12345 programmers.co.kr 2. 접근방법 먼저 n의 자리수를 구합니다! 자리수만큼의 배열 크기를 만들어줍니다! 이후 10으로 나머지한 값을 거꾸로 담기만 하면 완성! 3. 코드 class Solution { public int[] solution(long n) { int cnt = 0; long m ..

알고리즘 2021.06.04

백준 1018 : 체스판 다시 칠하기 (Java)

1. 문제링크 https://www.acmicpc.net/problem/1018 1018번: 체스판 다시 칠하기 첫째 줄에 N과 M이 주어진다. N과 M은 8보다 크거나 같고, 50보다 작거나 같은 자연수이다. 둘째 줄부터 N개의 줄에는 보드의 각 행의 상태가 주어진다. B는 검은색이며, W는 흰색이다. www.acmicpc.net 2. 접근방법 88 크기의 체스판으로 다시 칠하겠다고 한다. 즉! 88크기만큼의 BW, WB 체스판을 각각 구하고 더 작은 체스판과 대조한다면? 정답이 나올것이라고 생각했다. 만들어둔 BW, WB 체스판에다가 하나하나 대조하여 카운트를 세고 더 작은 체스판으로 넣어준다면 된다! 3. 코드 import java.io.BufferedReader; import java.io.Inp..

알고리즘 2021.06.02

프로그래머스 : 문자열 내림차순으로 배치하기 (Java)

1. 문제링크 https://programmers.co.kr/learn/courses/30/lessons/12917 코딩테스트 연습 - 문자열 내림차순으로 배치하기 문자열 s에 나타나는 문자를 큰것부터 작은 순으로 정렬해 새로운 문자열을 리턴하는 함수, solution을 완성해주세요. s는 영문 대소문자로만 구성되어 있으며, 대문자는 소문자보다 작은 것으로 programmers.co.kr 2. 접근방법 임시 변수에 담아서 정렬을 한번 하고 나서 끝에서부터 다시 answer에 추가해서 보내준다! 3. 코드 import java.util.*; class Solution { public String solution(String s) { String answer = ""; char[] temp = new cha..

알고리즘 2021.05.30

프로그래머스 : 메뉴 리뉴얼 (Java)

1. 문제링크 https://programmers.co.kr/learn/courses/30/lessons/72411 코딩테스트 연습 - 메뉴 리뉴얼 레스토랑을 운영하던 스카피는 코로나19로 인한 불경기를 극복하고자 메뉴를 새로 구성하려고 고민하고 있습니다. 기존에는 단품으로만 제공하던 메뉴를 조합해서 코스요리 형태로 재구성해서 programmers.co.kr 2. 접근방법 2명이상의 손님이 먹을 수 있는 메뉴! 메뉴 구성은 2개 코스로 나올 수 있는 모든 요리 수 즉! 조합이다! 그리고 그 조합을 가지고 "만약 가장 많이 함께 주문된 메뉴 구성이 여러 개라면, 모두 배열에 담아 return 하면 됩니다." 라는 말이 있기 때문에 조합에서 나올 수 있는 명수를 체크하고 같을 경우에는 추가로 담아주는 작업이..

알고리즘 2021.05.24