분류 전체보기
프로그래머스 숫자 짝꿍 with 자바
https://school.programmers.co.kr/learn/courses/30/lessons/131128 풀이 X와 Y가 가지고 있는 숫자들 중에서 중복된 숫자들만 찾으면 된다 우선 X를 한 글자씩 돌면서, 해당 숫자를 카운트 해준다 int[] count = new int[10]; // X가 가지고 있는 숫자 담을 배열 // X의 숫자 카운트 for (int i = 0; i < X.length(); i++) { char c = X.charAt(i); int n = c - '0'; count[n]++; } 그 후, Y를 한 글자씩 돌면서, 해당 숫자를 X가 가지고 있는지 확인하고 X가 가지고 있다면, 카운트에서 값을 하나 빼준다 이러면 X와 Y가 중복으로 가지고 있는 숫자임을 찾은 셈이므로 중복..
백준 1541 잃어버린 괄호 with 자바
https://www.acmicpc.net/problem/1541 풀이 먼저 "-"를 기준으로 문자열을 쪼개 준다 55-50+40의 경우 문자열을 쪼개면 55와 50+40으로 쪼갤 수 있으며 String 배열에 {"55", "50+40"}으로 담을 수 있다 이제, 배열의 0번 인덱스부터 뒤로 가면서 배열의 원소에 있는 수식을 계산하고, 계산한 결과를 빼주면 된다 0번 인덱스인 55에서 다음 원소인 50+40을 계산하고, 계산 결과인 90을 빼주면 된다 더하기만 있는 수식을 계산하는 함수이다 static int sumFormula(String s) { String[] ss = s.split("\\+"); int sum = 0; for (int i = 0; i < ss.length; i++) { sum +=..
백준 1043 거짓말 with 자바
https://www.acmicpc.net/problem/1043 풀이 먼저 각 파티에 있는 사람끼리 그래프로 연결하고 각 파티마다 진실을 알고 있는 사람이 있는 경우 해당 파티에 있는 나머지 사람들도 진실을 알고 있다고 상태를 변경한 다음 다시 한번 전체 파티를 돌면서 파티에 진실을 알고 있는 사람이 한 명이라도 있는 경우 전체 파티 개수에서 파티 개수를 빼주면 된다 전역 변수를 다음과 같이 선언해준다 static int N; static int M; static boolean[] visited; // 최종적으로 진실을 알고있는 사람 static Queue knowns; // 처음에 진실을 알고있는 사람 static Input[] inputs; // 받은 입력값 저장 (파티 정보) static Link..
백준 2636 치즈 with 자바
https://www.acmicpc.net/problem/2636 풀이 테두리(0,0)에서부터 2차원 배열을 치즈가 다 없어질 때까지 반복적으로 전체 탐색하면 된다 탐색할 때는 4방향 탐색을 하여 치즈가 있는 경우는 해당 위치를 기억하고 탐색이 다 끝나면 해당 위치의 치즈를 삭제해 주면 된다 전역 변수를 선언해 주고 static int N; static int M; static boolean[][] arr;// 2차원 배열 static int totalCount;// 전체 치즈 개수 static int[] di = {-1, 1, 0, 0};// 4방향 탐색에 쓰일 행 인덱스 static int[] dj = {0, 0, 1, -1};// 4방향 탐색에 쓰일 열 인덱스 static boolean[][] vi..
백준 5430 AC with 자바
https://www.acmicpc.net/problem/5430 풀이 더블리 링크드 리스트를 학습하기 아주 좋은 예제이다 진짜 그냥 더블리 링크드 리스트 구현해서 풀면 된다 링크드 리스트에 사용할 노드 클래스를 구현해주고 private static class Node { int n; Node pre; Node next; public Node(int n) { this.n = n; } } head와 tail을 선언하고 head와 tail 중 어떤 노드를 가리키는지 표시할 current와 아무것도 없는데 D를 한 경우를 확인하기 위한 에러 플래그를 선언해준다 static Node head; static Node tail; static Node current; static Boolean flag; 숫자 차례대..
백준 2096 내려가기 with 자바
https://www.acmicpc.net/problem/2096 풀이 윗 줄에서 부터 최대 / 최소값을 더해가면사 내려가면 된다 어떤 위치( [i][j] ) 에서의 최대값은 윗 줄( [i-1][j-1], [i-1][j], [i-1][j+1] ) 중에서 최대값인 녀석을 선택하여 해당 위치( [i][j] ) 에 더해주면 된다 예를 들어 배열이 1 2 3 4 5 6 4 9 0 인경우 2번째 줄 (4 5 6) 부터 시작하여 4는 윗줄 중에 가장 큰 2, 5는 3, 6은 3 과 더하면 6 8 9 4 9 0 이 된다 이제 그 다음 줄 (4 9 0)에서 계산을 하면 4는 윗줄 중에 가장 큰 8, 9는 9, 0은 9 와 더하면 결과는 12, 18 ,9 가 되며 최대값은 18이 된다 해당 로직을 구현한 코드이다 sta..
백준 7662 이중 우선순위 큐 with 자바
https://www.acmicpc.net/problem/7662 풀이 문제 제목이 우선순위 큐라고 해서 진짜 우선순위 큐로 풀면 안 된다 이 문제는 기본적인 자료구조를 잘 알고 있는지 묻는 문제이다 특히 Tree에 관한 자료구조를 잘 알고 있어야 한다 필자는 TreeMap을 이용하여 문제를 풀었다 똑같은 숫자를 여러 개 저장하는 경우도 있으므로 숫자의 카운트를 위해 TreeSet보다는 TreeMap을 사용하였다 물론 TreeSet을 사용하는 경우, 해당 숫자의 개수를 별도로 카운트해주면 문제를 풀 수 있긴 할 것이다 하지만 숫자의 범위가 너무 넓으므로, 각 숫자의 개수를 따로 카운트해주는 것은 별로인 듯하다 입력 받는 숫자의 범위가 32비트 정수이므로 숫자를 저장할 key는 long형으로, 해당 숫자의..
싸피 모바일반 2학기 근황
싸피에 들어온 지 10개월 차가 되었다 현재 싸피 2학기 자율프로젝트를 달리는 중이다🏃♂️ 현재까지 싸피에서 쌓은 업적들이다 성적우수상 3등🥉 프로젝트 상보다 더 받기 어려운 상인 듯 진짜 열심히 하는 사람한테 준다 성적우수 받으려면 쥰내 열심히 하자 단, SW 역량테스트 모의 등급 높은 사람이 우선순위가 가장 높다 마일리지 제일 두둑하게 준다 개꿀 공통프로젝트 3등🥉 프로젝트 상들 중에서 가장 받기 힘든 상인 것 같다 2학기에 들어와서 본격적으로 시작하는 첫 프로젝트인 만큼 다들 열정이 대단하다 다들 프로젝트에 미쳐있다😱 다들 적당히가 없다 대부분의 팀들이 매일 밤새가며 작업을 하기 때문에 상 받기 즈응말 힘들다 특화프로젝트 1등🥇 개인적으로 가장 재미있었다😁 역시 새로운 것을 배우는 것은 항상 재밌..
펀딩해보는 컨트랙트 만들어보기
요구사항 1. 일정 기간 동안 이더를 지불하여 모금에 참여 가능 2. 모금, 현재 모금액 보기, 모금액 수령 기능을 제공 기본 구조 Remix에 새로운 sol 파일을 만들고 기본 구조를 작성함 // SPDX-License-Identifier: GPL-3.0 pragma solidity >=0.7.0 = MINIMUM_AMOUT, "MINUMUM AMOUNT: 0.01 ether"); require(block.timestamp < fundRaisingCloses, "FUND RAISING CLOSED"); address funder = msg.sender; funders.push(funder); } } 현재 모금액을 볼 수있는 함수 현재 컨트랙트가 가지고 있는 잔액을 반환 값을 호출만 하므로 view로 선..