프로그래머스 2단계 주식가격 문제 url : https://programmers.co.kr/learn/courses/30/lessons/62048?language=java 문제설명가로 길이가 Wcm, 세로 길이가 Hcm인 직사각형 종이가 있습니다. 종이에는 가로, 세로 방향과 평행하게 격자 형태로 선이 그어져 있으며, 모든 격자칸은 1cm x 1cm 크기입니다. 이 종이를 격자 선을 따라 1cm × 1cm의 정사각형으로 잘라 사용할 예정이었는데, 누군가가 이 종이를 대각선 꼭지점 2개를 잇는 방향으로 잘라 놓았습니다. 그러므로 현재 직사각형 종이는 크기가 같은 직각삼각형 2개로 나누어진 상태입니다. 새로운 종이를 구할 수 없는 상태이기 때문에, 이 종이에서 원래 종이의 가로, 세로 방향과 평행하게 1cm..
프로그래머스 1단계 2020 카카오공채 문자열 압축 url : https://programmers.co.kr/learn/courses/30/lessons/60057?language=java 문제설명데이터 처리 전문가가 되고 싶은 어피치는 문자열을 압축하는 방법에 대해 공부를 하고 있습니다. 최근에 대량의 데이터 처리를 위한 간단한 비손실 압축 방법에 대해 공부를 하고 있는데, 문자열에서 같은 값이 연속해서 나타나는 것을 그 문자의 개수와 반복되는 값으로 표현하여 더 짧은 문자열로 줄여서 표현하는 알고리즘을 공부하고 있습니다. 간단한 예로 aabbaccc의 경우 2a2ba3c(문자가 반복되지 않아 한번만 나타난 경우 1은 생략함)와 같이 표현할 수 있는데, 이러한 방식은 반복되는 문자가 적은 경우 압축률이..
개발을 하다가 다음과 같은 문제가 발생했다. API 호출로 전달받은 JSON 객체에 대문자로 시작되는 필드명이 존재했다. 특정 필드는 대문자로 시작하고, 특정 필드는 소문자로 시작하고 ...규칙성이 존재하지 않는다. 그리고 대문자로 시작하는 필드명은 옳지 않다고 생각한다! 그래서 필드명의 시작은 모두 소문자로 시작될 수 있게 변경했다. 먼저 객체를 순회하는 방법을 먼저 알아보려고 한다. Object.keys(item) 를 사용하면 객체가 가지고 있는 필드명을 배열의 형태로 반환을 한다.반복문을 통해 순차적으로 접근하면 해당 객체의 필드명을 알 수 있다. 필드명을 알고 있다면 해당 객체의 값도 알 수 있다. - Key Names : Object.keys(item); - Value : item['key na..
Clean Code 관련된 내용을 매주 하나씩 정리를 해보려고 한다. Clean Code 관련된 내용은 책에서는 많이 봤고, 머릿속으로는 알고 있지만 잘 지켜지지 않는다.항상 타협하게 된다. 책과 현실은 다르다고! 2020년부터는 좀더 우아한 프로그래밍을 하기 위해 ... 글을 작성하면서 정리도 하고, 실천도 해볼려고 한다. 의미있는 변수 사용 변수, 메소드 이름이 길더라도 명확하게 의도가 추측될 수 있도록 명명하는 것이 중요하다! 당연하고, 간단한 내용이지만 실제 개발을 할 때, 대부분의 개발자들이 네이밍에 많은 시간을 투자하고 어려워한다. 이름은 굉장히 중요하다! 아래의 예를 보면, 첫번째 코딩도 의도를 충분히 추측할 수 있지만, 객체에 메세지를 전달하는 두번째 방식이 가독성, 메소드를 이용한 재사용..
흔히, script는 HTML 끝에 선언을 해야, 페이지 로딩 시 지연이 발생하지 않는다고 하는데, 왜 그럴까? 라는 의문으로 시작했다.웹 브라우저에서 HTML, CSS, JS 는 어떻게 화면에 그려질까? 1. LoadingHTTP 모듈 또는 파일시스템으로 전달받은 리소스 스트림을 읽는 과정으로 Loader가 역할을 담당하고 있다. 2. ParsingParsing은 HTML, XML Parser를 이용해서 DOM Tree, CSSOM Tree를 생성하는 과정이다. 3. Rendering TreeRendering Tree = Dom Tree + CSSOM Tree 라고 할 수 있다. Rendering Tree는 화면에 표시하기 위한 위치, 크기 정보, 그리기 순서 등을 저장하기 위한 트리이다. 지금까지 D..
프로그래머스 2단계 점프와 순간이동 문제 url : https://programmers.co.kr/learn/courses/30/lessons/12980 문제설명OO 연구소는 한 번에 K 칸을 앞으로 점프하거나, (현재까지 온 거리) x 2 에 해당하는 위치로 순간이동을 할 수 있는 특수한 기능을 가진 아이언 슈트를 개발하여 판매하고 있습니다. 이 아이언 슈트는 건전지로 작동되는데, 순간이동을 하면 건전지 사용량이 줄지 않지만, 앞으로 K 칸을 점프하면 K 만큼의 건전지 사용량이 듭니다. 그러므로 아이언 슈트를 착용하고 이동할 때는 순간 이동을 하는 것이 더 효율적입니다. 아이언 슈트 구매자는 아이언 슈트를 착용하고 거리가 N 만큼 떨어져 있는 장소로 가려고 합니다. 단, 건전지 사용량을 줄이기 위해 점..
프로그래머스 2단계 짝지어 제거하기 문제 url : https://programmers.co.kr/learn/courses/30/lessons/12973 문제설명짝지어 제거하기는, 알파벳 소문자로 이루어진 문자열을 가지고 시작합니다. 먼저 문자열에서 같은 알파벳이 2개 붙어 있는 짝을 찾습니다. 그다음, 그 둘을 제거한 뒤, 앞뒤로 문자열을 이어 붙입니다. 이 과정을 반복해서 문자열을 모두 제거한다면 짝지어 제거하기가 종료됩니다. 문자열 S가 주어졌을 때, 짝지어 제거하기를 성공적으로 수행할 수 있는지 반환하는 함수를 완성해 주세요. 성공적으로 수행할 수 있으면 1을, 아닐 경우 0을 리턴해주면 됩니다. 예를 들어, 문자열 S = baabaa 라면 b aa baa → bb aa → aa → 의 순서로 문..
프로그래머스 2단계 구명보트 문제 url : https://programmers.co.kr/learn/courses/30/lessons/42885?language=java 문제설명무인도에 갇힌 사람들을 구명보트를 이용하여 구출하려고 합니다. 구명보트는 작아서 한 번에 최대 2명씩 밖에 탈 수 없고, 무게 제한도 있습니다. 예를 들어, 사람들의 몸무게가 [70kg, 50kg, 80kg, 50kg]이고 구명보트의 무게 제한이 100kg이라면 2번째 사람과 4번째 사람은 같이 탈 수 있지만 1번째 사람과 3번째 사람의 무게의 합은 150kg이므로 구명보트의 무게 제한을 초과하여 같이 탈 수 없습니다. 구명보트를 최대한 적게 사용하여 모든 사람을 구출하려고 합니다. 사람들의 몸무게를 담은 배열 people과 구..
천년만에 포스팅을 한다. 이직 성공해도 ... 포스팅은 놓치지 않을거에요! 라고 생각을 했는데 ..어느새 나의 소중한 블로그가 잊혀졌다. 그리고 오늘부터 다시 포스팅을 시작했다. 인수테스트에서 내가 동작하기 원하는 특정 인수테스트만을 자동으로 실행할 수 있는 프로그램을 개발이 필요했다. 요구사항은 간단하게 아래와 같다. 1. api.v1 패키지에 있는 인수테스트 중, Exhibition이라는 특정 단어가 포함된 인수테스만을 실행시킨다. 2. 새로운 인수테스트를 작성해도, 자동으로, 동적으로 테스트를 수행할 수 있는 프로그램을 개발한다. 3. 기존 테스트 코드에 대한 수정을 최소화한다. 리플랙션을 활용하면 쉽게 해결할 수 있는 문제였다. 그러나 프로그래밍 과정에서 문제가 하나 있었다. 인수테스트 실행을 위..
1. Java 구현 (1) 풀이 - 1 (성공) (수정 필요) package Q1159; import java.io.*; import java.util.*; import java.util.stream.Collectors; import java.util.stream.Stream; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out)); int n = Inte..