2차원 격자공간에 두 개의 꼭짓점 좌표로 표현되는 직사각형이 있다. 직사각형은 아래와 같이 왼쪽 아래 꼭짓점 좌표 (x, y)와 오른쪽 위 꼭짓점 좌표 (p, q)로 주어진다.
이 문제에서 모든 직사각형은 두 꼭짓점의 좌표를 나타내는 4개의 정수 x y p q 로 표현된다. 단 항상 x<p, y<q 이다. 예를 들어 (3,2) (9,8) 의 두 점이 주어진다면 아래와 같이 표현된다.
3 2 9 8
두 개의 직사각형은 그 겹치는 부분의 특성에 따라 다음 4가지 경우로 분류될 수 있다.
먼저 두 직사각형의 겹치는 부분이 직사각형인 경우(a)이다.
겹치는 부분이 (b)와 같이 선분이 될 수도 있고, (c)와 같이 점도 될 수 있다.
마지막으로 (d)와 같이 공통부분 없이 두 직사각형이 완전히 분리된 경우도 있다.
여러분은 두 직사각형의 겹치는 부분이 직사각형인지, 선분인지, 점인지, 아니면 전혀 없는 지를 판별해서 해당되는 코드 문자를 출력해야 한다.
직사각형 => a
선분 => b
점 => c
공통부분이 없음 => d
4개의 줄로 이루어져 있다. 각 줄에는 8개의 정수가 하나의 공백을 두고 나타나는데, 첫 4개의 정수는 첫 번째 직사각형을, 나머지 4개의 정수는 두 번째 직사각형을 각각 나타낸다. 단 입력 직사각형의 좌표 값은 1이상 50,000 이하의 정수로 제한된다.
4개의 각 줄에 주어진 두 직사각형의 공통부분을 조사해서 해당하는 코드 문자를 출력파일의 첫 4개의 줄에 각각 차례대로 출력해야 한다.
#(x1, y1, p1, q1) (x2, y2, p2, q2)
3 10 50 60 100 100 200 300
45 50 600 600 400 450 500 543
11 120 120 230 50 40 60 440
35 56 67 90 67 80 500 600
d
a
a
b
def main():
import sys
input = sys.stdin.read
data = input().strip().split('\n')
for line in data:
x1, y1, p1, q1, x2, y2, p2, q2 = map(int, line.split())
if x1 > p2 or y1 > q2 or x2 > p1 or y2 > q1:
print("d")
elif (x1 == p2 and y1 == q2) or (x2 == p1 and y2 == q1) or (x1 == p2 and q1 == y2) or (x2 == p1 and q2 == y1):
print("c")
elif x1 == p2 or y1 == q2 or x2 == p1 or y2 == q1:
print("b")
else:
print("a")
if __name__ == "__main__":
main()