ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [백준] 11758. CCW
    PS/Java 2022. 3. 31.

    2차원 좌표 평면 위에 있는 점 3개 P1, P2, P3가 주어진다. P1, P2, P3를 순서대로 이은 선분이 어떤 방향을 이루고 있는지 구하는 프로그램을 작성하시오.


    입력

    첫째 줄에 P1의 (x1, y1), 둘째 줄에 P2의 (x2, y2), 셋째 줄에 P3의 (x3, y3)가 주어진다. (-10,000 ≤ x1, y1, x2, y2, x3, y3 ≤ 10,000) 모든 좌표는 정수이다. P1, P2, P3의 좌표는 서로 다르다.

    출력

    P1, P2, P3를 순서대로 이은 선분이 반시계 방향을 나타내면 1, 시계 방향이면 -1, 일직선이면 0을 출력한다.


    예제 입력 1

    1 1
    5 5
    7 3

    예제 출력 1

    -1

    import java.io.BufferedReader;
    import java.io.BufferedWriter;
    import java.io.InputStreamReader;
    import java.io.OutputStreamWriter;
    import java.util.StringTokenizer;
    
    public class Main {
        public static BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        public static BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
        public static class Point {
            int x;
            int y;
    
            public Point(int x, int y) {
                this.x = x;
                this.y = y;
            }
        }
        public static void main(String[] args) throws Exception {
            StringTokenizer st = new StringTokenizer(br.readLine());
            Point p1 = new Point(Integer.parseInt(st.nextToken()), Integer.parseInt(st.nextToken()));
            st = new StringTokenizer(br.readLine());
            Point p2 = new Point(Integer.parseInt(st.nextToken()), Integer.parseInt(st.nextToken()));
            st = new StringTokenizer(br.readLine());
            Point p3 = new Point(Integer.parseInt(st.nextToken()), Integer.parseInt(st.nextToken()));
    
            int res = p1.x * p2.y + p2.x * p3.y + p3.x * p1.y;
            res = res - p1.y * p2.x - p2.y * p3.x - p3.y * p1.x;
            
            if(res > 0) {
                bw.write("1");
            } else if (res == 0) {
                bw.write("0");
            } else {
                bw.write("-1");
            }
            br.close();
            bw.flush();
            bw.close();
        }
    }

    아래 글을 참고하면 좋을 것 같습니다.

     

    https://www.acmicpc.net/blog/view/27

    'PS > Java' 카테고리의 다른 글

    [백준] 1629. 곱셈  (0) 2022.03.31
    [백준] 2573. 빙산  (0) 2022.03.31
    [백준] 3495. 아스키 도형  (0) 2022.03.31
    [백준] 15649. N과 M (1)  (0) 2022.03.31
    [백준] 5430. AC  (0) 2022.03.31

    댓글

Designed by Tistory.