본문 바로가기

분류 전체보기383

20230822 [Java] 문제풀이 20230822 [Java] 문제풀이 [프로그래머스] 혼자 놀기의 달인 상자에 카드를 넣고 무작위로 섞어 일렬로 나열한다 그리고 상자를 1번부터 순차적으로 증가하는 번호를 붙인다 상자 번호에서, 카드 번호를 보고, 카드 번호에 대한 상자 번호를 여는 것이다 인덱스를 상자 번호라고 생각하면 카드 번호에 1을 항상 빼야한다 import java.util.*; class Solution { public int solution(int[] cards) { ArrayList group = new ArrayList(); int[] visited = new int[cards.length]; for (int i = 0; i < cards.length; i ++) { int tempCount = 0; if (visited.. 2023. 8. 22.
20230821 [Java] 문제풀이 20230821 [Java] 문제풀이 [프로그래머스] 두 큐 합 같게 만들기 이 문제는 두 큐가 주어지고, 서로의 원소를 주고 받으면서, 서로의 원소들의 값이 같을 수 있도록 만드는 것이다 제일 주의해야할 점은, 두 개의 큐가 있다는 것이다 서로 원소를 주고 받을 때에, 제일 먼저 큐에 들어온 원소를, 다른 큐에게 전달할 수 있다는 점이다 각 두 큐의 값을 구하고, 그 값에 따라, 값이 더 큰 큐에서, 더 작은 큐에게 원소를 주는 방식으로 로직을 짜면 된다 while문이 무한 루프에 빠질 수 있는 상황이 있어서, answer가 나올 수 있는 최대의 수를 정해준다 (answer > queue1.length * 4) 두 개의 큐의 합이 같으면, 바로 answer를 출력해준다 answer는 원소의 움직임의 개.. 2023. 8. 21.
20230819 [Java] 문제풀이 20230819 [Java] 문제풀이 [프로그래머스] 할인 행사 HashMap에 원하는 제품과, 그 수량을 넣는다 그리고 10일 단위로, Discount를 순회하면서, HashMap에 있는 제품과 동일한 제품이 있으면 하나씩 빼준다 즉 10일 단위로 갱신이 될 때마다 새로운 HashMap을 가지고 와야 한다 그래서 copy 라는 메서드를 따로 만들었다 그렇게 10개를 모두 살 수 있으면 answer에다가 1을 누적시키면 된다 제발 문제를 잘 읽자!!!!!!! import java.util.*; class Solution { public static HashMap copy(HashMap list) { HashMap newList = new HashMap(); for (String key : list.key.. 2023. 8. 19.
20230817 [Java] 문제풀이 20230817 [Java] 문제풀이 [프로그래머스] 귤 고르기 해쉬맵으로 문제를 풀었다 해쉬맵에 귤 사이즈를 key, 사이즈에 대한 개수를 value로 넣었다 value기준으로 최소한의 종류를 구했다 (value를 배열에 넣고 내림차순으로 정렬했다) import java.util.*; class Solution { public int solution(int k, int[] tangerine) { int answer = 0; HashMap map = new HashMap(); ArrayList array = new ArrayList(); for (int num : tangerine) { if (map.containsKey(num)) { map.put(num, map.get(num) + 1); } else.. 2023. 8. 17.
20230816 [Java] 문제풀이 20230816 [Java] 문제풀이 [프로그래머스] 디펜스 게임 첫 풀이는 71.9 로, 시간 초과 때문에 실패를 했다 2 중 for문으로, slicing을 하고, 정렬을 하면서 앞의 숫자 위주로 더하면서 정답을 구했다 import java.util.*; class Solution { public int solution(int n, int k, int[] enemy) { int answer = 0; if (k == enemy.length) return k; if (k > enemy.length) return enemy.length; for (int i = enemy.length; i >= k; i--) { int[] newEnemy = new int[i]; int tempAdd = 0; int temp.. 2023. 8. 16.
20230815 [Java] 문제풀이 20230815 [Java] 문제풀이 [프로그래머스] 택배 배달과 수거하기 기본적으로 뒤에서부터 택배를 수거 또는 배달해야, 최소 이동 거리를 구할 수 있다 뒤에서부터 천천히 수거 또는 배달의 개수를 순회한다 deliver 또는 pickup의 개수가 음수일 경우 트럭에 택배를 실을 공간이 있다는 것이다 반대로 양수일 경우에는 해당 지점을 while문을 통해 계속 왕복을 해야 한다 (해당 지점에서 택배를 다 처리할 때까지, 즉 음수가 될 때까지) class Solution { public long solution(int cap, int n, int[] deliveries, int[] pickups) { long answer = 0; long deliver = 0; long pickup = 0; // 뒤에서.. 2023. 8. 15.
스프링 스프링 출처 : 제로베이스 백엔드 스쿨 스프링 프레임워크란? 스프링 프레임워크는 자바 기반 오픈소스 웹 프레임워크다 엔터프라이즈급 어플리케이션, 즉 대규모 데이터 처리와 트랜잭션이 동시에 여러 사용자로 부터 행해지는 큰 규모의 환경에 사용할 수 있는 프레임워크다 정해진 틀에 맞춰서, 개발을 하는 것이다 (틀에 내가 개발한 클래스를 넣기만 하면 된다) 어느정도 맞춰진 틀이 있어서, 자유도는 떨어지지만, 개발하기 편하다 스프링 Bean이라는 규격에 맞춰 만들면 서로가 서로를 가져다 쓰기가 좋다 OOP (객체지향 프로그래밍) 컴퓨터는 주로 순서대로 코드를 읽는다 그 코드가 한 두줄이면 보기 편하지만, 만줄, 그 이상의 코드가 있으면 사람이 읽기 매우 불편하다 객체지향 프로그램을 통해서 분류 그리고 교체를 할 .. 2023. 8. 14.
[Java] Open API와 JSON 활용하기 [Java] Open API와 JSON 활용하기 서울 공공 WIFI Open API 가져오기 https://data.seoul.go.kr/dataList/OA-20883/S/1/datasetView.do 위 주소를 통해서 API를 사용하기 위한 key와 사용법에 대해 읽는다 Open API 사용하기 PDF 파일에는 프로그래밍 언어마다 API를 사용하는 코드가 다 나와 있어서, 복사 붙여 넣기만 하면 된다 JSON 활용하기 JSON 라이브러리를 다운로드 받는다 https://code.google.com/archive/p/json-simple/downloads File -> Project Stucture -> Dependencies -> + -> 라이브러리 선택 코드 package test; import o.. 2023. 8. 7.
20230804 [Java] 문제풀이 20230804 [Java] 문제풀이 [프로그래머스] 무인도 여행 DFS만 잘 구현하면 쉽게 풀 수 있는 내용이었다 일단 방문처리를 하면서 섬을 탐색하면서 count에다가 maps에 있는 숫자들을 더해주면 된다 import java.util.*; class Solution { public static int[] dr = {-1, 0, 0, 1}; public static int[] dc = {0, -1, 1, 0}; public static String[][] realMap; public static int[][] visited; public static int count; public static int dfs(int row, int column) { for (int i = 0; i < 4; i++) .. 2023. 8. 4.