시간 제한메모리 제한제출정답맞힌 사람정답 비율
2 초 256 MB119251931.667%

문제

N(1 ≤ N ≤ 100,000)개의 선분이 주어졌을 때, 서로 겹치는 서로 다른 선분 쌍의 개수를 알아내는 프로그램을 작성하시오. 두 선분이 겹친다는 말은, 두 선분에 공통적으로 포함되는 점들이 무한 개 존재한다는 의미이다. 즉, 선분의 끝점만 닿아 있는 경우는 겹치는 경우가 아닌 것이다.

입력

첫째 줄에 정수 N이 주어진다. 다음 N개의 줄에는 각 선분의 양 끝점의 x, y좌표를 나타내는 네 정수가 주어진다. 각 좌표는 0이상 1,000,000의 값을 가지며, 한 선분의 양 끝점이 같은 경우는 주어지지 않는다.

출력

첫째 줄에 답을 출력한다.

예제 입력 1

3
1 1 2 2
2 2 3 3
1 1 3 3

예제 출력 1

2
W3sicHJvYmxlbV9pZCI6IjIwODAiLCJwcm9ibGVtX2xhbmciOiIwIiwidGl0bGUiOiJcdWFjYjlcdWNlNThcdWIyOTQgXHVjMTIwXHViZDg0IiwiZGVzY3JpcHRpb24iOiI8cD5OKDEgJmxlOyBOICZsZTsgMTAwLDAwMClcdWFjMWNcdWM3NTggXHVjMTIwXHViZDg0XHVjNzc0IFx1YzhmY1x1YzViNFx1Yzg0Y1x1Yzc0NCBcdWI1NGMsIFx1YzExY1x1Yjg1YyBcdWFjYjlcdWNlNThcdWIyOTQgXHVjMTFjXHViODVjIFx1YjJlNFx1Yjk3OCBcdWMxMjBcdWJkODQgXHVjMzBkXHVjNzU4IFx1YWMxY1x1YzIxOFx1Yjk3YyBcdWM1NGNcdWM1NDRcdWIwYjRcdWIyOTQgXHVkNTA0XHViODVjXHVhZGY4XHViN2E4XHVjNzQ0IFx1Yzc5MVx1YzEzMVx1ZDU1OFx1YzJkY1x1YzYyNC4gXHViNDUwIFx1YzEyMFx1YmQ4NFx1Yzc3NCBcdWFjYjlcdWNlNWNcdWIyZTRcdWIyOTQgXHViOWQwXHVjNzQwLCBcdWI0NTAgXHVjMTIwXHViZDg0XHVjNWQwIFx1YWNmNVx1ZDFiNVx1YzgwMVx1YzczY1x1Yjg1YyBcdWQzZWNcdWQ1NjhcdWI0MThcdWIyOTQgXHVjODEwXHViNGU0XHVjNzc0IFx1YmIzNFx1ZDU1YyBcdWFjMWMgXHVjODc0XHVjN2FjXHVkNTVjXHViMmU0XHViMjk0IFx1Yzc1OFx1YmJmOFx1Yzc3NFx1YjJlNC4gXHVjOTg5LCBcdWMxMjBcdWJkODRcdWM3NTggXHViMDVkXHVjODEwXHViOWNjIFx1YjJmZlx1YzU0NCBcdWM3ODhcdWIyOTQgXHVhY2JkXHVjNmIwXHViMjk0IFx1YWNiOVx1Y2U1OFx1YjI5NCBcdWFjYmRcdWM2YjBcdWFjMDAgXHVjNTQ0XHViMmNjIFx1YWM4M1x1Yzc3NFx1YjJlNC48XC9wPlxyXG4iLCJpbnB1dCI6IjxwPlx1Y2NhYlx1YzlmOCBcdWM5MDRcdWM1ZDAgXHVjODE1XHVjMjE4IE5cdWM3NzQgXHVjOGZjXHVjNWI0XHVjOWM0XHViMmU0LiBcdWIyZTRcdWM3NGMgTlx1YWMxY1x1Yzc1OCBcdWM5MDRcdWM1ZDBcdWIyOTQgXHVhYzAxIFx1YzEyMFx1YmQ4NFx1Yzc1OCBcdWM1OTEgXHViMDVkXHVjODEwXHVjNzU4IHgsIHlcdWM4OGNcdWQ0NWNcdWI5N2MgXHViMDk4XHVkMGMwXHViMGI0XHViMjk0IFx1YjEyNCBcdWM4MTVcdWMyMThcdWFjMDAgXHVjOGZjXHVjNWI0XHVjOWM0XHViMmU0LiBcdWFjMDEgXHVjODhjXHVkNDVjXHViMjk0IDBcdWM3NzRcdWMwYzEgMSwwMDAsMDAwXHVjNzU4IFx1YWMxMlx1Yzc0NCBcdWFjMDBcdWM5YzBcdWJhNzAsIFx1ZDU1YyBcdWMxMjBcdWJkODRcdWM3NTggXHVjNTkxIFx1YjA1ZFx1YzgxMFx1Yzc3NCBcdWFjMTlcdWM3NDAgXHVhY2JkXHVjNmIwXHViMjk0IFx1YzhmY1x1YzViNFx1YzljMFx1YzljMCBcdWM1NGFcdWIyOTRcdWIyZTQuPFwvcD5cclxuIiwib3V0cHV0IjoiPHA+XHVjY2FiXHVjOWY4IFx1YzkwNFx1YzVkMCBcdWIyZjVcdWM3NDQgXHVjZDljXHViODI1XHVkNTVjXHViMmU0LjxcL3A+XHJcbiIsImhpbnQiOiIiLCJvcmlnaW5hbCI6IjAiLCJodG1sX3RpdGxlIjoiMCIsInByb2JsZW1fbGFuZ190Y29kZSI6IktvcmVhbiJ9LHsicHJvYmxlbV9pZCI6IjIwODAiLCJwcm9ibGVtX2xhbmciOiIxIiwidGl0bGUiOiJMaW5lIFNlZ21lbnRzIiwiZGVzY3JpcHRpb24iOiI8cD5MaW5lIHNlZ21lbnRzIGFyZSBhIHZlcnkgY29tbW9uIGVsZW1lbnQgaW4gY29tcHV0YXRpb25hbCBnZW9tZXRyeS4gQSBsaW5lIHNlZ21lbnQgaXMgdGhlIHNldCBvZiBwb2ludHMgZm9ybWluZyB0aGUgc2hvcnRlc3QgcGF0aCBiZXR3ZWVuIHR3byBwb2ludHMgKGluY2x1ZGluZyB0aG9zZSBwb2ludHMpLiBBbHRob3VnaCB0aGV5IGFyZSBhIHZlcnkgYmFzaWMgY29uY2VwdCBpdCBjYW4gYmUgaGFyZCB0byB3b3JrIHdpdGggdGhlbSBpZiB0aGV5IGFwcGVhciBpbiBodWdlIG51bWJlcnMgdW5sZXNzIHlvdSBoYXZlIGFuIGVmZmljaWVudCBhbGdvcml0aG0uPFwvcD5cclxuXHJcbjxwPkdpdmVuIGEgc2V0IG9mIGxpbmUgc2VnbWVudHMsIGNvdW50IGhvdyBtYW55IGRpc3RpbmN0IHBhaXJzIG9mIGxpbmUgc2VnbWVudHMgYXJlIG92ZXJsYXBwaW5nLiBUd28gbGluZSBzZWdtZW50cyBhcmUgc2FpZCB0byBiZSBvdmVybGFwcGluZyBpZiB0aGV5IGludGVyc2VjdCBpbiBhbiBpbmZpbml0ZSBudW1iZXIgb2YgcG9pbnRzLjxcL3A+XHJcbiIsImlucHV0IjoiPHA+VGhlIGZpcnN0IGxpbmUgY29udGFpbnMgdGhlIG51bWJlciBvZiBzY2VuYXJpb3MuPFwvcD5cclxuXHJcbjxwPkVhY2ggc2NlbmFyaW8gc3RhcnRzIHdpdGggdGhlIG51bWJlciBuIG9mIGxpbmUgc2VnbWVudHMgKDEgJmxlOyBuICZsZTsgMTAwMDAwKS4gVGhlbiBmb2xsb3cgbiBsaW5lcyBjb25zaXN0aW5nIG9mIGZvdXIgaW50ZWdlcnMgeDEsIHkxLCB4MiwgeTIgaW4gdGhlIHJhbmdlIFswLCAxMDAwMDAwXSBlYWNoLCByZXByZXNlbnRpbmcgYSBsaW5lIHNlZ21lbnQgdGhhdCBjb25uZWN0cyB0aGUgcG9pbnRzICh4MSwgeTEpIGFuZCAoeDIsIHkyKS4gSXQgaXMgZ3VhcmFudGVlZCB0aGF0IGEgbGluZSBzZWdtZW50IGRvZXMgbm90IGRlZ2VuZXJhdGUgdG8gYSBzaW5nbGUgcG9pbnQuPFwvcD5cclxuIiwib3V0cHV0IjoiPHA+VGhlIG91dHB1dCBmb3IgZXZlcnkgc2NlbmFyaW8gYmVnaW5zIHdpdGggYSBsaW5lIGNvbnRhaW5pbmcgJmxkcXVvO1NjZW5hcmlvICNpOiZyZHF1bzssIHdoZXJlIGkgaXMgdGhlIG51bWJlciBvZiB0aGUgc2NlbmFyaW8gc3RhcnRpbmcgYXQgMS4gVGhlbiBwcmludCBhIHNpbmdsZSBsaW5lIGNvbnRhaW5pbmcgdGhlIG51bWJlciBvZiBkaXN0aW5jdCBwYWlycyBvZiBvdmVybGFwcGluZyBsaW5lIHNlZ21lbnRzIGZvbGxvd2VkIGJ5IGFuIGVtcHR5IGxpbmUuIEhpbnQ6IFRoZSBudW1iZXIgb2Ygb3ZlcmxhcHBpbmcgcGFpcnMgbWF5IG5vdCBmaXQgaW50byBhIDMyLWJpdCBpbnRlZ2VyLjxcL3A+XHJcbiIsImhpbnQiOiIiLCJvcmlnaW5hbCI6IjEiLCJodG1sX3RpdGxlIjoiMCIsInByb2JsZW1fbGFuZ190Y29kZSI6IkVuZ2xpc2gifV0=