전체 글

전체 글

    [코딩 테스트] 코딩 테스트에서 필요한 Python 문법 정리

    [코딩 테스트] 코딩 테스트에서 필요한 Python 문법 정리

    본 포스팅은 코딩테스트를 치뤄보면서 필요한 문법들을 정리해 본 글입니다. 지극히 주관적일 수 있으니 보충 및 수정이 필요하다면 댓글로 남겨주세요. 숫자관련 문법 숫자와 관련하여 반올림, factorial, 최소공배수 등 다양한 연산 및 계산이 필요한 경우가 있다. 그래서 숫자 연산과 관련된 문법을 아래와 같이 정리해보려고 합니다. 더하기[ A+B ] : A와 B를 더한 값을 계산한다. 빼기[ A-B ] : A에 B를 뺀 값을 계산한다. 곱하기[ A*B ] : A에 B를 곱한 값을 계사한다. 나누기[ A/B ] : A에 B를 나눈 값을 계산한다. 몫[ A//B ] : A에 B를 나눴을때의 몫을 계산한다. 나머지[ A%B ]: A에 B를 나누고 난 나머지를 계산한다. 거듭제곱[ A**B ] ..

    [백준] 1260번 : DFS와 BFS(Python)

    [백준] 1260번 : DFS와 BFS(Python)

    문제설명 그래프를 DFS로 탐색한 결과와 BFS로 탐색한 결과를 출력하는 프로그램을 작성하시오. 단, 방문할 수 있는 정점이 여러 개인 경우에는 정점 번호가 작은 것을 먼저 방문하고, 더 이상 방문할 수 있는 점이 없는 경우 종료한다. 정점 번호는 1번부터 N번까지이다. 입력 첫째 줄에 정점의 개수 N(1 ≤ N ≤ 1,000), 간선의 개수 M(1 ≤ M ≤ 10,000), 탐색을 시작할 정점의 번호 V가 주어진다. 다음 M개의 줄에는 간선이 연결하는 두 정점의 번호가 주어진다. 어떤 두 정점 사이에 여러 개의 간선이 있을 수 있다. 입력으로 주어지는 간선은 양방향이다. 출력 첫째 줄에 DFS를 수행한 결과를, 그 다음 줄에는 BFS를 수행한 결과를 출력한다. V부터 방문된 점을 순서대로 출력하면 된다..

    [백준] 1904번 : 01타일(Python)

    [백준] 1904번 : 01타일(Python)

    문제설명 지원이에게 2진 수열을 가르쳐 주기 위해, 지원이 아버지는 그에게 타일들을 선물해주셨다. 그리고 이 각각의 타일들은 0 또는 1이 쓰여 있는 낱장의 타일들이다. 어느 날 짓궂은 동주가 지원이의 공부를 방해하기 위해 0이 쓰여진 낱장의 타일들을 붙여서 한 쌍으로 이루어진 00 타일들을 만들었다. 결국 현재 1 하나만으로 이루어진 타일 또는 0타일을 두 개 붙인 한 쌍의 00타일들만이 남게 되었다. 그러므로 지원이는 타일로 더 이상 크기가 N인 모든 2진 수열을 만들 수 없게 되었다. 예를 들어, N=1일 때 1만 만들 수 있고, N=2일 때는 00, 11을 만들 수 있다. (01, 10은 만들 수 없게 되었다.) 또한 N=4일 때는 0011, 0000, 1001, 1100, 1111 등 총 5개의..

    [백준] 1010번 : 다리놓기(Python)

    [백준] 1010번 : 다리놓기(Python)

    문제설명 재원이는 한 도시의 시장이 되었다. 이 도시에는 도시를 동쪽과 서쪽으로 나누는 큰 일직선 모양의 강이 흐르고 있다. 하지만 재원이는 다리가 없어서 시민들이 강을 건너는데 큰 불편을 겪고 있음을 알고 다리를 짓기로 결심하였다. 강 주변에서 다리를 짓기에 적합한 곳을 사이트라고 한다. 재원이는 강 주변을 면밀히 조사해 본 결과 강의 서쪽에는 N개의 사이트가 있고 동쪽에는 M개의 사이트가 있다는 것을 알았다. (N ≤ M) 재원이는 서쪽의 사이트와 동쪽의 사이트를 다리로 연결하려고 한다. (이때 한 사이트에는 최대 한 개의 다리만 연결될 수 있다.) 재원이는 다리를 최대한 많이 지으려고 하기 때문에 서쪽의 사이트 개수만큼 (N개) 다리를 지으려고 한다. 다리끼리는 서로 겹쳐질 수 없다고 할 때 다리를..

    [백준] 9095번 : 1, 2, 3 더하기(Python)

    [백준] 9095번 : 1, 2, 3 더하기(Python)

    문제설명 정수 4를 1, 2, 3의 합으로 나타내는 방법은 총 7가지가 있다. 합을 나타낼 때는 수를 1개 이상 사용해야 한다. 1+1+1+1 1+1+2 1+2+1 2+1+1 2+2 1+3 3+1 정수 n이 주어졌을 때, n을 1, 2, 3의 합으로 나타내는 방법의 수를 구하는 프로그램을 작성하시오. 입력 첫째 줄에 테스트 케이스의 개수 T가 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있고, 정수 n이 주어진다. n은 양수이며 11보다 작다. 출력 각 테스트 케이스마다, n을 1, 2, 3의 합으로 나타내는 방법의 수를 출력한다. 전체코드(Python) def case(n): # 1,2,3일때 1,2,3으로 구할 수 있는 경우의 수를 미리 구해놓는다 num = [0,1,2,4] # 4부터는 맨앞이 ..

반응형