express 시작하기
2021. 10. 28. 15:27
🚦 Server/Node.js
1. express 시작하기 패키지 설치 $ npm install express 설치하고 app.js 파일을 만들어보자. 외부 클라이언트로부터 받은 url path 부분이 '/hello' 라면, 그 함수가 실행된다. 이렇게 특정 조건이 만족되었을 때 실행되는 함수가 콜백이라고 했다. 특정 path에 대응하는 콜백을 route handler 라고도 한다. route handler : 특정 path를 대상으로 한, 특정 메소드를 가진 리퀘스트를 처리해주는 함수 route : 서버가 각 req의 path 부분을 보고 알맞은 작업을 수행하는 것 handler : 그 작업을 담당하는 존재 request : 이 객체를 통해 클라이언트가 보낸 객체를 다룰 수 있다. response : 이 객체를 통해 적절한 resp..
합이 같은 부분집합(DFS : 아마존 인터뷰)
2021. 10. 28. 11:53
⏰ 코딩테스트/BFS, DFS
합이 같은 부분집합(DFS : 아마존 인터뷰) N개의 원소로 구성된 자연수 집합이 주어지면, 이 집합을 두 개의 부분집합으로 나누었을 때 두 부분집합의 원소의 합이 서로 같은 경우가 존재하면 “YES"를 출력하고, 그렇지 않으면 ”NO"를 출력하는 프로그램을 작성하세요. 둘로 나뉘는 두 부분집합은 서로소 집합이며, 두 부분집합을 합하면 입력으로 주어진 원래의 집합이 되어 합니다. 예를 들어 {1, 3, 5, 6, 7, 10}이 입력되면 {1, 3, 5, 7} = {6, 10} 으로 두 부분집합의 합이 16으로 같은 경우가 존재하는 것을 알 수 있습니다. ▣ 입력설명 첫 번째 줄에 자연수 N(1
부분집합 구하기(DFS)
2021. 10. 28. 10:40
⏰ 코딩테스트/BFS, DFS
부분집합 구하기(DFS) 자연수 N이 주어지면 1부터 N까지의 원소를 갖는 집합의 부분집합을 모두 출력하는 프로그램을 작성하세요. ▣ 입력설명 첫 번째 줄에 자연수 N(1
프로그래머스 - 1단계 - MySQL
2021. 10. 27. 12:01
⏰ 코딩테스트/MySQL
모든 레코드 조회하기 SELECT ANIMAL_ID, ANIMAL_TYPE, DATETIME, INTAKE_CONDITION, name, sex_upon_intake from animal_ins order by animal_id asc; 역순 정렬하기 SELECT name, datetime from animal_ins order by animal_id desc; 아픈 동물 찾기 SELECT animal_id, name from animal_ins where intake_condition='Sick' 어린 동물 찾기 select animal_id, name from animal_ins where intake_condition !='aged' 여러 기준으로 정렬하기 select animal_id, name,..
이진트리 순회(깊이우선탐색)
2021. 10. 27. 10:28
⏰ 코딩테스트/BFS, DFS
이진트리 순회(깊이우선탐색) 아래 그림과 같은 이진트리를 전위순회와 후위순회를 연습해보세요. 전위순회 출력 : 1 2 4 5 3 6 7 중위순회 출력 : 4 2 5 1 6 3 7 후위순회 출력 : 4 5 2 6 7 3 1 전위 순회 def DFS(v): if v>7: return else: print(v) # 본래 함수의 일을 먼저 한다. 전위순회 DFS(v*2) DFS(v*2+1) if __name__=="__main__": n = int(input()) DFS(n) 중위 순회 def DFS(v): if v>7: return else: DFS(v*2) print(v) # 본래 함수의 일을 중간에 한다. 중위순회 DFS(v*2+1) if __name__=="__main__": n = int(input()..
재귀함수를 이용한 이진수 출력
2021. 10. 27. 09:35
⏰ 코딩테스트/BFS, DFS
재귀함수를 이용한 이진수 출력 10진수 N이 입력되면 2진수로 변환하여 출력하는 프로그램을 작성하세요. 단 재귀함수를 이용해서 출력해야 합니다. ▣ 입력설명 첫 번째 줄에 10진수 N(1
git commit 다루기
2021. 10. 26. 18:26
🚦 Server/git
commit 히스토리 보기 $ git log 가장 오래된 커밋 메시지가 가장 아래에 있고 최근 커밋이 맨 위에 있다. commit 다음 길게 써져있는 문자열은 커밋 아이디이다. 깃은 각각의 커밋을 구별하기 위해 아이디를 붙여서 관리한다. commit hash 라고도 한다. 커밋을 한 사람과 커밋 한 시간까지 나와 있다. 더 깔끔하게 봐보자 q를 눌러 나가주자. $ git log --pretty=oneline 커밋 로그를 이쁘게 한줄씩 출력하기 그럼 어떤 파일이 어떻게 변했는지 알아보자. README 파일은 어떻게 변했을까? $ git show 1d53 여기서 --- 까지가 해당 커밋 이전의 모습이고 그밑에 +++ 까지가 해당 커밋 이후의 모습이다. m 옵션 없이 commit message 남기기 $ gi..
서드파티 모듈, npm 이해하기
2021. 10. 26. 10:38
🚦 Server/Node.js
모듈을 require 할 때의 과정 require('sample')로 모듈을 로드할 때, sample.js 라는 파일로 존재하는 모듈을 로드할 수 있고, sample 이라는 디렉토리 안의 모듈을 로드할 수 있다. 디렉토리 이름인 경우 오른쪽 절차에 따라 로드한다. 서드파티 모듈을 로드할 때는, 모듈의 이름이 디렉토리인 경우, 그 안에 package.json이라는 포함하고 있는 지 확인한다. 그렇니까 서드파티 모듈은 package.json 이라는 파일을 가지는 디렉토리인 것이다. 서드파티 모듈을 로드할 때의 경로 package.json 파일을 가진 디렉토리 형태로 존재하기 때문이다. 그렇기 때문에 서드파티 모듈의 이름이 디렉토리 이름과 같았던 것이다. 정리하자면 패키지 안에 package.json 파일이 ..
재귀함수와 스택 작동 원리
2021. 10. 26. 09:59
⏰ 코딩테스트/BFS, DFS
재귀 함수는 3중, 4중 for문 써야할 때 쓰면 좋다. def DFS(x): if x > 0: DFS(x-1) print(x) if __name__=="__main__": n = int(input()) DFS(n) 3을 입력하면 출력은 1, 2, 3 순으로 출력된다. 왜그럴까? 왜냐하면 재귀함수는 스택으로 작동하기 때문이다. DFS(3) 을 하면 매개변수 x = 3 지역변수 복귀주소 이 세개가 스택에 쌓인다. □ □ □ x=0, DFS(1) 복귀주소 □ □ x=1, DFS(2) 복귀주소 □ □ x=2, DFS(3) 복귀주소 □ □ x=3, 지역변수,복귀주소 □ □□□□□□□□□□□□□ 하나의 묶음을 스택 프레임이라고도 한다. 스택 프레임을 하나씩 처리하고 복귀하면서 끝이 나게 된다. 그렇기 때문에 1,..
최대힙
2021. 10. 23. 16:47
⏰ 코딩테스트/자료구조 활용
최대힙 최대힙은 완전이진트리로 구현된 자료구조입니다. 그 구성은 부모 노드값이 왼쪽자식과 오른쪽 자식노드의 값보다 크게 트리를 구성하는 것입니다. 그렇게 하면 트리의 루트(root)노드는 입력된 값들 중 가장 큰 값이 저장되어 있습니다. 예를 들어 5 3 2 1 4 6 7 순으로 입력되면 최대힙 트리는 아래와 같이 구성됩니다. 최대힙 자료를 이용하여 다음과 같은 연산을 하는 프로그램을 작성하세요. 1) 자연수가 입력되면 최대힙에 입력한다. 2) 숫자 0 이 입력되면 최대힙에서 최댓값을 꺼내어 출력한다. (출력할 자료가 없으면 -1를 출력한다.) 3) -1이 입력되면 프로그램 종료한다. ▣ 입력설명 첫 번째 줄부터 숫자가 입력된다. 입력되는 숫자는 100,000개 이하이며 각 숫자의 크기는 정수형 범위에 ..
최소힙
2021. 10. 23. 16:10
⏰ 코딩테스트/자료구조 활용
최소힙 최소힙은 완전이진트리로 구현된 자료구조입니다. 그 구성은 부모 노드값이 왼쪽 자식과 오른쪽 자식노드의 값보다 작게 트리를 구성하는 것입니다. 그렇게 하면 트리의 루트(root)노드는 입력된 값들 중 가장 작은 값이 저장되어 있습니다. 예를 들어 5 3 2 1 4 6 7 순으로 입력되면 최소힙 트리는 아래와 같이 구성됩니다. 최소힙 자료를 이용하여 다음과 같은 연산을 하는 프로그램을 작성하세요. 1) 자연수가 입력되면 최소힙에 입력한다. 2) 숫자 0 이 입력되면 최소힙에서 최솟값을 꺼내어 출력한다. (출력할 자료가 없으면 -1를 출력한다.) 3) -1이 입력되면 프로그램 종료한다. ▣ 입력설명 첫 번째 줄부터 숫자가 입력된다. 입력되는 숫자는 100,000개 이하이며 각 숫자의 크기는 정수형 범위..
git, GitHub 시작하기
2021. 10. 22. 17:32
🚦 Server/git
git 이란? git : 버전관리 하는 프로그램 Github : git으로 관리하는 프로그램을 올려둘 수 있는 곳이 github, 원격저장소 commit : 프로젝트 디렉토리의 모습을 하나의 버전으로 남기는 행위 & 결과물 repository : commit이 저장되는 곳 .git : repository git init : 비어있는 레포지토리를 생성 commit 시 주의사항 commit : 이 순간을 기억해줘 commit을 할때는 누가 했는지 남겨야 한다. 협업할 때 어떤 커밋을 누가 했는지 구별하기 위해서 한다. 처음으로 커밋할 때 : 사용자 이름, 이메일 주소 $ git config user.name "SunWooChan" $ git config user.email "swc5770@naver.com"..
아나그램(딕셔너리 해쉬)
2021. 10. 22. 11:01
⏰ 코딩테스트/자료구조 활용
아나그램(딕셔너리 해쉬) Anagram이란 두 문자열이 알파벳의 나열 순서를 다르지만 그 구성이 일치하면 두 단어는 아나그램이라고 합니다. 예를 들면 AbaAeCe 와 baeeACA 는 알파벳을 나열 순서는 다르지만 그 구성을 살펴보면 A(2), a(1), b(1), C(1), e(2)로 알파벳과 그 개수가 모두 일치합니다. 즉, 어느 한 단어를 재배열하면 상대편 단어가 될 수 있는 것을 아나그램이라 합니다. 길이가 같은 두 개의 단어가 주어지면 두 단어가 아나그램인지 판별하는 프로그램을 작성하세요. 아나그램 판별시 대소문자가 구분됩니다. ▣ 입력설명 첫 줄에 첫 번째 단어가 입력되고, 두 번째 줄에 두 번째 단어가 입력됩니다. 단어의 길이는 100을 넘지 않습니다. ▣ 출력설명 두 단어가 아나그램이면 ..
단어 찾기(해쉬)
2021. 10. 22. 09:47
⏰ 코딩테스트/자료구조 활용
단어 찾기(해쉬) 현수는 영어로 시는 쓰는 것을 좋아합니다. 현수는 시를 쓰기 전에 시에 쓰일 단어를 미리 노트에 적어둡니다. 이번에는 N개의 단어를 노트에 적었는데 시에 쓰지 않은 단어가 하나 있다고 합니다. 여러분이 찾아 주세요. ▣ 입력설명 첫 번째 줄에 자연수 N(3
프로그래머스 2단계 - 괄호
2021. 10. 21. 21:13
⏰ 코딩테스트/프로그래머스
문제 설명 괄호가 바르게 짝지어졌다는 것은 '(' 문자로 열렸으면 반드시 짝지어서 ')' 문자로 닫혀야 한다는 뜻입니다. 예를 들어 "()()" 또는 "(())()" 는 올바른 괄호입니다. ")()(" 또는 "(()(" 는 올바르지 않은 괄호입니다. '(' 또는 ')' 로만 이루어진 문자열 s가 주어졌을 때, 문자열 s가 올바른 괄호이면 true를 return 하고, 올바르지 않은 괄호이면 false를 return 하는 solution 함수를 완성해 주세요. 제한사항 문자열 s의 길이 : 100,000 이하의 자연수 문자열 s는 '(' 또는 ')' 로만 이루어져 있습니다. 입출력 예 "()()" true "(())()" true ")()(" false "(()(" false 풀이 스택 자료구조 활용 ( ..
교육과정 설계(큐)
2021. 10. 21. 11:37
⏰ 코딩테스트/자료구조 활용
교육과정 설계(큐) 현수는 1년 과정의 수업계획을 짜야 합니다. 수업중에는 필수과목이 있습니다. 이 필수과목은 반드시 이수해야 하며, 그 순서도 정해져 있습니다. 만약 총 과목이 A, B, C, D, E, F, G가 있고, 여기서 필수과목이 CBA로 주어지면 필수과목은 C, B, A과목이며 이 순서대로 꼭 수업계획을 짜야 합니다. 여기서 순서란 B과목은 C과목을 이수한 후에 들어야 하고, A과목은 C와 B를 이수한 후에 들어야 한다는 것입니다.현수가 C, B, D, A, G, E로 수업계획을 짜면 제대로 된 설계이지만 C, G, E, A, D, B 순서로 짰다면 잘 못 설계된 수업 계획이 됩니다. 수업계획은 그 순서대로 앞에 수업이 이수되면 다음 수업을 시작하다는 것으로 해석합니다. 수업계획서 상의 각 ..