Plite
전자오락 공방
Plite
전체 방문자
오늘
어제
  • 분류 전체보기 (274)
    • 프로젝트 (18)
      • 완성 프로젝트 (3)
      • 프로젝트 진행 내역 (15)
    • 공부 및 정리 (241)
      • 백준 코드 (222)
      • C++ (8)
      • DirectX (2)
      • Unreal Engine (6)
      • 프로그래밍 패턴 (3)
    • 기타 (12)
      • 기타 주저리 (10)
    • 게임과 취미 (1)
    • 대문 (1)

블로그 메뉴

  • 홈
  • 프로젝트
  • 취미, 일상
  • 백준 프로필

공지사항

  • [Read Me]
  • 제 블로그에 방문하신 것을 환영합니다.

인기 글

태그

  • 스택
  • 트리
  • 세그먼트 트리
  • 백트래킹
  • 정렬
  • 위상 정렬
  • 기하
  • 최소 스패닝 트리
  • SCC
  • 트라이
  • 백준
  • LCA
  • 문자열
  • 이분탐색
  • 조합론
  • 수학
  • C++
  • 브루트포스
  • 분할정복
  • 우선순위큐
  • 투포인터
  • 큐
  • 구현
  • 그래프
  • 유니온 파인드
  • UC++
  • KMP
  • 동적계획법
  • 누적합
  • 정수론

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Plite

전자오락 공방

[C++]백준 - 11758번 문제
공부 및 정리/백준 코드

[C++]백준 - 11758번 문제

2021. 10. 17. 17:29

11758번: CCW (acmicpc.net)

 

11758번: CCW

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

www.acmicpc.net

 

11758번 : CCW


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을 출력한다.

 


 

생각해 볼 점


해당 문제는 세 점이 주어지며, CCW(반시계 방향인지 확인하는 알고리즘)를 사용합니다.

 

점 3개의 방향성을 나타내는 CCW (acmicpc.net)

 

점 3개의 방향성을 나타내는 CCW

세 점 P1(x1, y1), P2(x2, y2), P3(x3, y3)가 있을 떄, 점 3개를 이은 선분은 어떤 방향성을 나타내게 될까요? 11758번 문제: CCW 가능한 경우의 수는 총 3가지가 있습니다. 반시계 방향, 시계 방향, 일직선. 시

www.acmicpc.net

 

위 링크의 내용을 함수로 작성하면 금방 풀립니다.

 

코드


#include <iostream>
using namespace std;

int ccw(pair<int, int> p[])
{
    int temp1 = p[0].first * p[1].second + p[1].first * p[2].second + p[2].first * p[0].second;
    int temp2 = p[0].second * p[1].first + p[1].second * p[2].first + p[2].second * p[0].first;
    int result = temp1 - temp2;
    if(result < 0) return -1;
    else if(result > 0) return 1;
    else return 0;
}

int main() 
{
    pair<int, int> points[3];
    
    for(int i = 0; i < 3; i++) cin >> points[i].first >> points[i].second;
    cout << ccw(points);
	return 0;
}

 

그 외


 

저작자표시 (새창열림)

'공부 및 정리 > 백준 코드' 카테고리의 다른 글

[C++]백준 - 1009번 문제  (0) 2021.10.18
[C++]백준- 2618번 문제  (0) 2021.10.18
[C++]백준 - 2166번 문제  (0) 2021.10.17
[C++]백준 - 9252번 문제  (0) 2021.10.06
[C++]백준 - 23057번 문제  (0) 2021.10.06
    '공부 및 정리/백준 코드' 카테고리의 다른 글
    • [C++]백준 - 1009번 문제
    • [C++]백준- 2618번 문제
    • [C++]백준 - 2166번 문제
    • [C++]백준 - 9252번 문제
    Plite
    Plite
    개발 일지, 게임 이야기 등을 적어두는 공간입니다.

    티스토리툴바