전체 글

Back-end Developer who want to develop a customer-satisfying service
문제 https://school.programmers.co.kr/learn/courses/30/lessons/77485 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 풀이 구현은 어렵지 않다. 백준의 배열돌리기 문제를 풀 수 있다면 해당 문제도 쉽게 풀 수 있다. 단순 구현하면 다음과 같다. import java.util.*; class Solution { static int[][] arr; public int[] solution(int rows, int columns, int[][] queries) { int[] answer = new int[queri..
문제 https://school.programmers.co.kr/learn/courses/30/lessons/64065 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 풀이 해당 문제를 처음 보았을 때 이해하기 어려웠는데 아래 두 입력케이스를 보면 이해할 수 있다. {{2},{2,1},{2,1,3},{2,1,3,4}} --> [2, 1, 3, 4] {{1,2,3},{2,1},{1,2,4,3},{2}} --> [2, 1, 3, 4] 두 케이스를 보면 결과가 같은데 2번째 케이스를 1번째 케이스처럼 원소의 개수대로 튜플을 크기순으로 정렬하고 보면 {{2},{2..
문제 https://school.programmers.co.kr/learn/courses/30/lessons/60057 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 풀이 자바에서는 substring 메서드를 이용해서 문자열을 자를 수 있다. 문자열을 1부터 n/2크기까지 자르고 첫번째로 자른 문자열 이후부터 첫번째 문자열과 비교하면서 일치하면 압축하면된다. 코드는 다음과 같이 작성하였다. import java.util.*; class Solution { public int solution(String s) { int answer = s.length();..
1. 스프링 부트 등장 배경 기본 스프링에서 필요한 모듈을 추가하다 보면 설정이 복잡해 지는 문제가 생긴다. 이러한 문제를 해결하기 위해 등장한 것이 스프링 부트이다. 2.스프링 부트의 특징 1.의존성 관리 스프링 프레임워크에서 각 모듈의 의존성을 직접 설정하고, 호환되는 버전을 명시해야 동작한다. 즉, 애플리케이션에서 사용하는 스프링 프레임워크나 라이브러리 버전을 올리는 상황에서 연관된 다른 라이브러리 버전도 고려해야함. 스프링부트에서 이 불편함을 해소하기 위해 'spring-boot-starter'라는 의존성을 제공한다. 각 라이브러리 기능과 관련해서 자주 사용되고 서로 호환되는 버전의 모듈 조합을 제공한다. 2. 자동설정 스프링 부투는 스프링 프레임워크의 기능을 사용하기 위한 자동설정을 지원한다. ..
사실 그날 바로 후기를 작성해야 했는데 그 당시에 쓰기도 귀찮았기도 했고 억지로 글을 쓰면 더 글을 쓰고 싶지 않기에 미루게 되었다. 휴대폰 갤러리를 오늘 살펴보니까 그 때의 기억이 나서 인프콘 후기를 작성해 보려고 한다. 일기 형식이니 퇴고를 거치지 않겠다. 한번 참여해 보자 난 이전에 컨퍼런스를 가본적이 없다. 가고 싶은 생각이 없었기도 했다. 크게 3가지로 나눌 수 있는데 첫번째 공간제약이다. 이전에 지방에 거주했던 나는 서울로 가기 귀찮았다. 행사장까지 이동시간으로 다시보기를 시청하면 되는게 아닌가? 시간을 효율적?으로 쓰고싶었다. 두번째는 나는 외부활동을 좋아하지 않는다. 컨퍼런스 같은 대형 행사에 참여해 본적 없으니 가서 혼자서 뭘 하지 막연한 생각도 들고 같이갈 사람이 없었다. 세번째 가본적..
· Infra/Docker
Docker file 생성 FROM node COPY . . NODE : 시스템이나 도커허브에 존재하는 이미지 이름 COPY 첫번째 경로 : 컨테이너 외부경로, 이미지의 외부경로로 이미지로 복사되어야 할 파일들이 있는 경로 두번째 경로 : 내부경로, 파일을 저장하는 이미지의 내부경로 여기에 '.'을 넣으면, 이는 도커에게 기본적으로 Dockerfile이 포함된 동일한 폴더임을 알리는 것이다. 하지만 Dockerfile은 제외된다. 첫 번째 '.'은 이 프로젝트의 모든 폴더, 하위 폴더 및 파일을 복사해야 한다고 도커에게 알리는 것이다. 두 번째 '.'은 그 파일을 저장해야 하는 이미지 내부의 경로다. 모든 이미지와 이미지를 기반으로 생성된 모든 컨테이너에는 로컬 머신의 파일 시스템에서 완전히 분리된 자체..
보호되어 있는 글입니다.
· BackEnd/JDBC
1. JDBC 정의 JDBC 또는 Java Database Connectivity는 데이터베이스와 쿼리를 연결하고 실행하기 위한 Java API JDBC 의 클래스와 인터페이스를 사용하면, 유저가 작성한 요청(쿼리문)을 지정된 데이타베이스에 송신할 수 있다. Java 데이터베이스 연결 표준을 갖춘 언어를 제공한다. Java는 표준 인터페이스인 JDBC API를 제공한다. (즉, 어떤 DBMS를 사용하더라도 똑같은 방식으로 다룰 수 있음 =(데이터 베이스 종류에 상관없다.) 자바를 이용한 DB 접속과 SQL 문장 실행, 실행 결과로 얻어진 데이터의 핸들링을 제공하는 방법과 절차에 관한 규약을 정의한다. 데이터베이스에 액세스하는 데 필요한 프로그램을 작성하는 데 사용된다. 1. JDBC 컴포넌트 JDBC에는..
문제 문제링크 SW Expert Academy SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요! swexpertacademy.com 풀이 규영이의 카드와 순서가 정해지고 인영이가 내는 순서에 따라 승패가 갈린다. 즉, 순열을 통해 인영이의 카드 순서의 경우의 수를 모두 구하고 승패 여부를 확인하면 된다. 순열을 구하는 방법은 대표적으로 두가지가 있는데 swap을 이용하여 순서를 구하거나 boolean 배열을 이용해 check하는 방법이다. 풀이1 import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.StringTokenizer; publi..
문제 문제링크 SW Expert Academy SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요! swexpertacademy.com 풀이 구현 문제이다. 두 유저가 이동할 때 사용할 수 있는 충전기 범위에 있다면 충전할 수 있는데 시간이 전부 흐르고 나서 두 유저가 최대로 충전할 수 있는 충전량을 구하는 문제다. 분기점은 다음과 같다. 두 유저가 충전 범위에 있을 때 두 유저가 사용할 수 있는 파워가 가장 큰 충전기가 같을 때 두 유저가 사용할 수 있는 충전기가 둘다 1개일 때 -> 한 유저가 충전기 사용을 포기하고 다른 유저가 사용 한 유저가(혹은 두 유저가) 사용할 수 있는 충전기가 2개일 때 -> 두개를 가지고 있는 유저가 파워가 큰 첫번째 충전기 사용을 양보하고 충전기를 ..
White Asher
sudo apt-get happiness