7578

알고리즘/acmicpc 2015. 7. 6. 18:15 Posted by 아는 개발자

문제를 푸는것 자체는 별로 어렵지 않았다. 


부분합 문제를 변형한 형태이기 때문에 그 점을 잘 파악해서 풀면 된다. 가장 왼쪽에 있는 기기 부터 전선을 하나씩 이어가며 교차점의 수를 늘려간다.


교차점의 수를 찾는 방법은 가장 오른쪽으로 떨어진 지점까지 현결된 전선의 개수와 현재의 위치에서 기계와 연결된 지점 까지의 전선 개수를 빼면 된다. 


가장 오른쪽으로 떨어진 점 까지의 연결된 전선의 개수는 교차 가능성이 있는 전선들이고 연결된 지점의 왼쪽에 있는 전선의 개수는 교차 가능성이 없는 전선들이기 때문에 둘의 차는 해당 지점에서 전선을 연결 했을 때 교점과 같다.




알고리즘은 쉽게 생각했는데 내가 틀렸던 이유는 교차점의 수가 int의 범위를 넘을 수 있다는 것을 생각하지 못했기 때문이다... 이미 틀려버린 3 문제가 정말 억울하다...


교차점은 0+1+2+...+499999까지 생기는데 이러면 int범위를 거뜬히 넘어버린다

앞으로 결과의 자료형은 왠만하면 long long을 사용해야겠다.



728x90

'알고리즘 > acmicpc' 카테고리의 다른 글

2458  (0) 2015.07.15
1365  (0) 2015.07.07
7578  (0) 2015.07.06
1753  (0) 2015.07.01
1795  (0) 2015.07.01
1197  (0) 2015.06.27