본문 바로가기

파이썬8

[Python] 코딩 테스트를 위한 파이썬 기본 문법 (자료형, 조건문) 코딩 테스트를 위한 파이썬 기본 문법 공채 시즌이 다시금 가까워졌다. 코딩 테스트 대비를 한동안 안 해서 코딩 감각이 무뎌진 느낌이라 기본적인 문법을 되돌아 보기로 하였다. 1. 자료형 정수형 a = 1000 print(a) a = -7 print(a) a = 0 print(a) 양의 정수, 음의 정수, 0 에 대한 입력과 출력 1000 -7 0 실수형 a = 157.93 print(a) a = -1837.2 print(a) a = 5. print(a) a = - .7 print(a) 양의 실수와 음의 실수의 입력과 출력 157.93 -1837.2 5.0 -0.7 출력 결과에서 볼 수 있듯이 소수부가 0이거나 정수부가 0인 소수는 0을 생략하고 작성할 수 있다. a = 1e9 print(a) a = 75.. 2021. 3. 15.
[python] 파이썬으로 보는 BFS 와 DFS 파이썬으로 알아 보는 BFS와 DFS 1. DFS, BFS 개념 가장 먼저 DFS(깊이 우선 탐색) 과 BFS(너비 우선 탐색) 의 개념에 대해서 알아보자. 먼저 그래프 그림을 보도록 하자. 기본적으로 Tree 형태의 그래프에서 사용하는 개념이다. 왼쪽의 BFS(너비 우선 탐색)은 깊이를 하나씩 내려가면서 그 레벨에 있는 노드를 전부 탐색하고 다음 레벨로 내려가면서 탐색하는 방법이고, 오른쪽의 DFS(깊이 우선 탐색)은 가장 위에 있는 부모 노드의 각 자식 노드의 모든 자식 노드들을 순서대로 탐색하는 방법이다. 2. DFS, BFS 구현 위의 그래프를 먼저 코드로 나타내보자 이어진 노드를 전부 표시한다. graph = { 'A': ['B', 'C', 'D'], 'B': ['A'], 'C': ['A', '.. 2020. 12. 17.
프로그래머스 - H-Index(Level 2) 프로그래머스 - H-Index(Level 2) 문제 설명 H-Index는 과학자의 생산성과 영향력을 나타내는 지표입니다. 어느 과학자의 H-Index를 나타내는 값인 h를 구하려고 합니다. 위키백과에 따르면, H-Index는 다음과 같이 구합니다. 어떤 과학자가 발표한 논문 n편 중, h번 이상 인용된 논문이 h편 이상이고 나머지 논문이 h번 이하 인용되었다면 h의 최댓값이 이 과학자의 H-Index입니다. 어떤 과학자가 발표한 논문의 인용 횟수를 담은 배열 citations가 매개변수로 주어질 때, 이 과학자의 H-Index를 return 하도록 solution 함수를 작성해주세요. 제한사항 과학자가 발표한 논문의 수는 1편 이상 1,000편 이하입니다. 논문별 인용 횟수는 0회 이상 10,000회 이.. 2020. 11. 14.
프로그래머스 - 다리를 지나는 트럭(Level 2) 프로그래머스 - 다리를 지나는 트럭(Level 2) 문제 설명 트럭 여러 대가 강을 가로지르는 일 차선 다리를 정해진 순으로 건너려 합니다. 모든 트럭이 다리를 건너려면 최소 몇 초가 걸리는지 알아내야 합니다. 트럭은 1초에 1만큼 움직이며, 다리 길이는 bridge_length이고 다리는 무게 weight까지 견딥니다. ※ 트럭이 다리에 완전히 오르지 않은 경우, 이 트럭의 무게는 고려하지 않습니다. 예를 들어, 길이가 2이고 10kg 무게를 견디는 다리가 있습니다. 무게가 [7, 4, 5, 6]kg인 트럭이 순서대로 최단 시간 안에 다리를 건너려면 다음과 같이 건너야 합니다. 경과 시간 다리를 지난 트럭 다리를 건너는 트럭 대기 트럭 0 [] [] [7,4,5,6] 1~2 [] [7] [4,5,6] .. 2020. 11. 9.
프로그래머스 - 짝지어 제거하기(Level 2) 프로그래머스 - 짝지어 제거하기(Level 2) 문제 설명 짝지어 제거하기는, 알파벳 소문자로 이루어진 문자열을 가지고 시작합니다. 먼저 문자열에서 같은 알파벳이 2개 붙어 있는 짝을 찾습니다. 그다음, 그 둘을 제거한 뒤, 앞뒤로 문자열을 이어 붙입니다. 이 과정을 반복해서 문자열을 모두 제거한다면 짝지어 제거하기가 종료됩니다. 문자열 S가 주어졌을 때, 짝지어 제거하기를 성공적으로 수행할 수 있는지 반환하는 함수를 완성해 주세요. 성공적으로 수행할 수 있으면 1을, 아닐 경우 0을 리턴해주면 됩니다. 예를 들어, 문자열 S = baabaa 라면 b aa baa → bb aa → aa → 의 순서로 문자열을 모두 제거할 수 있으므로 1을 반환합니다. 제한사항 문자열의 길이 : 1,000,000이하의 자.. 2020. 11. 7.
프로그래머스 - 기능개발(Level 2) 프로그래머스 - 기능개발(Level 2) 문제 설명 프로그래머스 팀에서는 기능 개선 작업을 수행 중입니다. 각 기능은 진도가 100%일 때 서비스에 반영할 수 있습니다. 또, 각 기능의 개발속도는 모두 다르기 때문에 뒤에 있는 기능이 앞에 있는 기능보다 먼저 개발될 수 있고, 이때 뒤에 있는 기능은 앞에 있는 기능이 배포될 때 함께 배포됩니다. 먼저 배포되어야 하는 순서대로 작업의 진도가 적힌 정수 배열 progresses와 각 작업의 개발 속도가 적힌 정수 배열 speeds가 주어질 때 각 배포마다 몇 개의 기능이 배포되는지를 return 하도록 solution 함수를 완성하세요. 제한 사항 작업의 개수(progresses, speeds배열의 길이)는 100개 이하입니다. 작업 진도는 100 미만의 자.. 2020. 11. 5.
프로그래머스 - 삼각달팽이(Level 2) 프로그래머스 - 삼각달팽이(Level 2) 문제 설명 정수 n이 매개변수로 주어집니다. 다음 그림과 같이 밑변의 길이와 높이가 n인 삼각형에서 맨 위 꼭짓점부터 반시계 방향으로 달팽이 채우기를 진행한 후, 첫 행부터 마지막 행까지 모두 순서대로 합친 새로운 배열을 return 하도록 solution 함수를 완성해주세요. 제한사항 n은 1 이상 1,000 이하입니다. 입출력 예 nresult 4 [1,2,9,3,10,8,4,5,6,7] 5 [1,2,12,3,13,11,4,14,15,10,5,6,7,8,9] 6 [1,2,15,3,16,14,4,17,21,13,5,18,19,20,12,6,7,8,9,10,11] 입출력 예 설명 입출력 예 #1 문제 예시와 같습니다. 입출력 예 #2 문제 예시와 같습니다. 입출.. 2020. 11. 2.
프로그래머스 - 스킬트리(Level 2) 프로그래머스 - 스킬트리(Level 2) 문제 설명 선행 스킬이란 어떤 스킬을 배우기 전에 먼저 배워야 하는 스킬을 뜻합니다. 예를 들어 선행 스킬 순서가 스파크 → 라이트닝 볼트 → 썬더일때, 썬더를 배우려면 먼저 라이트닝 볼트를 배워야 하고, 라이트닝 볼트를 배우려면 먼저 스파크를 배워야 합니다. 위 순서에 없는 다른 스킬(힐링 등)은 순서에 상관없이 배울 수 있습니다. 따라서 스파크 → 힐링 → 라이트닝 볼트 → 썬더와 같은 스킬트리는 가능하지만, 썬더 → 스파크나 라이트닝 볼트 → 스파크 → 힐링 → 썬더와 같은 스킬트리는 불가능합니다. 선행 스킬 순서 skill과 유저들이 만든 스킬트리를 담은 배열 skill_trees가 매개변수로 주어질 때, 가능한 스킬트리 개수를 return 하는 solut.. 2020. 10. 28.