프로그래밍
프로그래머스 숫자 짝꿍 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형으로, 해당 숫자의..
펀딩해보는 컨트랙트 만들어보기
요구사항 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로 선..
Remix와 Ganache로 컨트랙트 호출 & 배포 해보기
Remix에서 Ganache 프라이빗 네트워크에 컨트랙트 배포, 호출 하기 우선 프라이빗 네트워크를 구동해주고 ganache-cli -d -m -p 7545 -a 5 Remix에서 Environment를 Ganache Provider로 변경한다 *여기서는 3_Ballot.sol 파일을 이용하여 진행하였음 배포를 해보면 ganache에서 결과를 확인할 수 있다 Console에서 Ganache 프라이빗 네트워크에 컨트랙트 배포, 호출 하기 배포하기 다른 cmd 창을 열어서 프라이빗 네트워크에 연결을 해준다 geth attach http://localhost:7545 컨트랙트를 배포하기 위해서는 ABI와 바이트코드가 필요하다 ABI는 Remix에서 컴파일한 결과로 얻을 수 있다 바이트 코드는 Remix에서 컨..
트랜잭션에 데이터 담아 보내기
이전 글에서 트랜잭션을 이용하여 이더를 전송하였다 2022.08.23 - [프로그래밍/블록체인] - 이더리움 프라이빗 네트워크 만들고 MetaMask로 송금하기 이번에는 더 나아가 트랜잭션에 "hello erthereum" 메시지를 담아 보내보자 트랜잭션에서 data 필드에 데이터를 담아 보낼 수 있다 예시 eth_sendTransaction(from = '0xb117a8bc3ecf2c3f006b89da6826e49b4193977a', data = '0x8f8a0d190000000000000000000000000000000000000000000000000000000 0000000060000000000000000000000000000000000000000000000000000000000000002') et..