본문 바로가기

작업/Problem Solving

(61)
백준 1003(피보나치 함수) 파이썬(Python) 해결 www.acmicpc.net/problem/1003 1003번: 피보나치 함수 각 테스트 케이스마다 0이 출력되는 횟수와 1이 출력되는 횟수를 공백으로 구분해서 출력한다. www.acmicpc.net 문제 다음 소스는 N번째 피보나치 수를 구하는 C++ 함수이다. fibonacci(3)을 호출하면 다음과 같은 일이 일어난다. fibonacci(3)은 fibonacci(2)와 fibonacci(1) (첫 번째 호출)을 호출한다. fibonacci(2)는 fibonacci(1) (두 번째 호출)과 fibonacci(0)을 호출한다. 두 번째 호출한 fibonacci(1)은 1을 출력하고 1을 리턴한다. fibonacci(0)은 0을 출력하고, 0을 리턴한다. fibonacci(2)는 fibonacci(1)과..
백준 1100(하얀 칸) 파이썬(Python) 해결 문제 체스판은 8*8크기이고, 검정 칸과 하얀 칸이 번갈아가면서 색칠되어 있다. 가장 왼쪽 위칸 (0,0)은 하얀색이다. 체스판의 상태가 주어졌을 때, 하얀 칸 위에 말이 몇 개 있는지 출력하는 프로그램을 작성하시오. 입력 첫째 줄부터 8개의 줄에 체스판의 상태가 주어진다. ‘.’은 빈 칸이고, ‘F’는 위에 말이 있는 칸이다. 출력 첫째 줄에 문제의 정답을 출력한다. 하얀 칸의 값을 1로 가지는 체스판을 배열로 만들었습니다. 그다음 입력으로 받는 문자 ' . '은 0으로, 'F'는 1로 바꾼 다음 배열에 저장하였습니다. 마지막으로, 두 배열의 값이 모두 1인 개수를 구하여 해결하였습니다. board = [1,0,1,0,1,0,1,0,0,1,0,1,0,1,0,1, 1,0,1,0,1,0,1,0,0,1,0,..
백준 1002(터렛) 파이썬(python) 해결 문제 조규현의 좌표 (x1, y1)와 백승환의 좌표 (x2, y2)가 주어진다. 조규현이 계산한 류재명과의 거리 r1과 백승환이 계산한 류재명과의 거리 r2가 주어진다. 류재명이 있을 수 있는 좌표의 수를 출력하는 프로그램을 작성하시오. 입력 첫째 줄에 테스트 케이스의 개수 T가 주어진다. 각 테스트 케이스는 다음과 같이 이루어져 있다. 한 줄에 x1, y1, r1, x2, y2, r2가 주어진다. x1, y1, x2, y2는 -10,000보다 크거나 같고, 10,000보다 작거나 같은 정수이다. r1, r2는 10,000보다 작거나 같은 자연수이다. 출력 각 테스트 케이스마다 류재명이 있을 수 있는 위치의 수를 출력한다. 만약 류재명이 있을 수 있는 위치의 개수가 무한대일 경우에는 -1을 출력한다. 수..
백준 3053(택시 기하학) 파이썬(python) 해결 문제 19세기 독일 수학자 헤르만 민코프스키는 비유클리드 기하학 중 택시 기하학을 고안했다. 택시 기하학에서 두 점 T1(x1,y1), T2(x2,y2) 사이의 거리는 다음과 같이 구할 수 있다. D(T1,T2) = |x1-x2| + |y1-y2| 두 점 사이의 거리를 제외한 나머지 정의는 유클리드 기하학에서의 정의와 같다. 따라서 택시 기하학에서 원의 정의는 유클리드 기하학에서 원의 정의와 같다. 원: 평면 상의 어떤 점에서 거리가 일정한 점들의 집합 반지름 R이 주어졌을 때 유클리드 기하학에서 원의 넓이, 택시 기하학에서 원의 넓이를 구하는 프로그램을 작성하시오. 입력 첫째 줄에 반지름 R이 주어진다. R은 10,000보다 작거나 같은 자연수이다. 출력 첫째 줄에는 유클리드 기하학에서 반지름이 R인 ..
백준 4153(직각삼각형) 파이썬(python) 해결 문제 과거 이집트인들은 각 변들의 길이가 3, 4, 5인 삼각형이 직각 삼각형인것을 알아냈다. 주어진 세변의 길이로 삼각형이 직각인지 아닌지 구분하시오. 입력 입력은 여러개의 테스트케이스로 주어지며 마지막줄에는 0 0 0이 입력된다. 각 테스트케이스는 모두 30,000보다 작은 양의 정수로 주어지며, 각 입력은 변의 길이를 의미한다. 출력 각 입력에 대해 직각 삼각형이 맞다면 "right", 아니라면 "wrong"을 출력한다. 해답을 구하기 위해서 "피타고라스의 정리 공식"을 적용합니다. 예제 중 6, 8, 10의 경우를 보겠습니다. 6과 8이 각각 x와 y라고 했을 때 10이 z가 되며 계산이 일치하기 때문에 직각삼각형입니다. 공식을 성립 시키기 위해서는 입력된 3개의 값 중에서 가장 큰 값이 z가 되..
백준 3009(네 번째 점) 파이썬(python) 해결 문제 세 점이 주어졌을 때, 축에 평행한 직사각형을 만들기 위해서 필요한 네 번째 점을 찾는 프로그램을 작성하시오. 입력 세 점의 좌표가 한 줄에 하나씩 주어진다. 좌표는 1보다 크거나 같고, 1000보다 작거나 같은 정수이다. 출력 직사각형의 네 번째 점의 좌표를 출력한다. 값을 구하는 쉬운 방법은 세 점의 x와 y의 좌표 중에서 한 번만 언급된 것을 찾는 것입니다. 위의 그림은 예시 입력을 바탕으로 만든 직사각형입니다. 좌표 중에서 x값은 10이 2번 사용되었지만 30은 1번 사용 되었습니다. y값은 20이 2번 사용되었지만 10은 1번 사용되었습니다. 따라서 각 좌표 중 한 번만 사용된 값으로 (30, 10)이 마지막 점의 위치라는 것을 알 수 있습니다. python3 소스코드 # 백준 3009 (..
백준 1085(직사각형에서 탈출) 파이썬(python) 해결 문제 한수는 지금 (x, y)에 있다. 직사각형의 왼쪽 아래 꼭짓점은 (0, 0)에 있고, 오른쪽 위 꼭짓점은 (w, h)에 있다. 직사각형의 경계선까지 가는 거리의 최솟값을 구하는 프로그램을 작성하시오. 입력 첫째 줄에 x, y, w, h가 주어진다. 제한 ・ 1 ≤ w, h ≤ 1,000 ・ 1 ≤ x ≤ w-1 ・ 1 ≤ y ≤ h-1 ・ x, y, w, h는 정수 출력 첫째 줄에 문제의 정답을 출력한다. Python3 소스코드 # 백준 1085 (직사각형에서 탈출) x, y, w, h = input().split() # 문제에서 요구하는 범위를 벗어났을 경우 오류처리 if (1
백준 9020(골드바흐의 추측) 파이썬(python) 해결 문제 1보다 큰 자연수 중에서 1과 자기 자신을 제외한 약수가 없는 자연수를 소수라고 한다. 예를 들어, 5는 1과 5를 제외한 약수가 없기 때문에 소수이다. 하지만, 6은 6 = 2 × 3 이기 때문에 소수가 아니다. 골드바흐의 추측은 유명한 정수론의 미해결 문제로, 2보다 큰 모든 짝수는 두 소수의 합으로 나타낼 수 있다는 것이다. 이러한 수를 골드바흐 수라고 한다. 또, 짝수를 두 소수의 합으로 나타내는 표현을 그 수의 골드바흐 파티션이라고 한다. 예를 들면, 4 = 2 + 2, 6 = 3 + 3, 8 = 3 + 5, 10 = 5 + 5, 12 = 5 + 7, 14 = 3 + 11, 14 = 7 + 7이다. 10000보다 작거나 같은 모든 짝수 n에 대한 골드바흐 파티션은 존재한다. 2보다 큰 짝수..