프로그래머스 2단계 - 트럭
2021. 10. 31. 17:22
⏰ 코딩테스트/프로그래머스
코드 from collections import deque def solution(bridge_length, weight, truck_weights): answer = 0 dq = deque([0]*bridge_length) while len(truck_weights)!=0: # truck_weights 가 없어질 때까지 반복 dq.popleft() # 한칸 이동 # weight 보다 (deque의 합 + 다음 버스 무게)가 더 작으면, 한칸이동하고 다음 트럭 append if weight >= sum(dq) + truck_weights[0]: dq.append(truck_weights.pop(0)) # 다음 트럭 in answer += 1 else :# 그렇지 않으면 한칸 이동 dq.append(0) ..
프로그래머스 - 2단계 - MySQL
2021. 10. 28. 17:01
⏰ 코딩테스트/MySQL
IS NULL select animal_type, ifnull(name, 'No name'), sex_upon_intake from animal_ins order by animal_id 없어진 기록 찾기 select o.animal_id, o.name from animal_outs o left join animal_ins i on i.animal_id=o.animal_id where i.datetime is null order by o.animal_id 입양 간 기록은 있고 : outs 테이블은 다 입양 간 애들 보호소에 들어온 기록은 없으므로 : ins 테이블에는 datetime이 없는 애들이므로 outs ← left join ins 해주고 outs 테이블에서 동물들을 조회해주면 된다. 있었는데요 없었..
합이 같은 부분집합(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
재귀함수와 스택 작동 원리
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개 이하이며 각 숫자의 크기는 정수형 범위..
아나그램(딕셔너리 해쉬)
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 순서로 짰다면 잘 못 설계된 수업 계획이 됩니다. 수업계획은 그 순서대로 앞에 수업이 이수되면 다음 수업을 시작하다는 것으로 해석합니다. 수업계획서 상의 각 ..
응급실(큐)
2021. 10. 21. 09:45
⏰ 코딩테스트/자료구조 활용
응급실(큐) 메디컬 병원 응급실에는 의사가 한 명밖에 없습니다. 응급실은 환자가 도착한 순서대로 진료를 합니다. 하지만 위험도가 높은 환자는 빨리 응급조치를 의사가 해야 합니다. 이런 문제를 보완하기 위해 응급실은 다음과 같은 방법으로 환자의 진료순서를 정합니다. • 환자가 접수한 순서대로의 목록에서 제일 앞에 있는 환자목록을 꺼냅니다. • 나머지 대기 목록에서 꺼낸 환자 보다 위험도가 높은 환자가 존재하면 대기목록 제일 뒤로 다시 넣습니다. 그렇지 않으면 진료를 받습니다. 즉, 대기목록에 자기 보다 위험도가 높은 환자가 없을 때 자신이 진료를 받는 구조입니다. 현재 N명의 환자가 대기목록에 있습니다. N명의 대기목록 순서의 환자 위험도가 주어지면, 대기목록상의 M번째 환자는 몇 번째로 진료를 받는지 출..
공주 구하기(큐)
2021. 10. 20. 09:34
⏰ 코딩테스트/자료구조 활용
공주 구하기(큐) 정보 왕국의 이웃 나라 외동딸 공주가 숲속의 괴물에게 잡혀갔습니다. 정보 왕국에는 왕자가 N명이 있는데 서로 공주를 구하러 가겠다고 합니다. 정보왕국의 왕은 다음과 같은 방법으로 공주를 구하러 갈 왕자를 결정하기로 했습니다. 왕은 왕자들을 나이 순으로 1번부터 N번까지 차례로 번호를 매긴다. 그리고 1번 왕자부터 N번 왕자까지 순서대로 시계 방향으로 돌아가며 동그랗게 앉게 한다. 그리고 1번 왕자부터 시계방향으로 돌아가며 1부터 시작하여 번호를 외치게 한다. 한 왕자가 K(특정숫자)를 외치면 그 왕자는 공주를 구하러 가는데서 제외되고 원 밖으로 나오게 된다. 그리고 다음 왕자부터 다시 1부터 시작하여 번호를 외친다. 이렇게 해서 마지막까지 남은 왕자가 공주를 구하러 갈 수 있다. 예를 ..