N puncte numerotate de la 1 la N sunt aşezate pe cerc, în sensul acelor de ceasornic, în ordine strict crescătoare.
Există M segmente de dreaptă diferite care unesc M perechi de puncte dintre cele N date. Cele două puncte care formează orice pereche sunt distincte.
Distanţele dintre două puncte succesive sunt alese astfel încât să nu existe 3 sau mai multe segmente care trec printr-un acelaşi punct interior cercului.
Cerința
Cunoscându-se numărul de puncte, numărul de perechi şi perechile de puncte care vor fi unite, se cere să se determine numărul P de puncte de intersecţie formate de acestea în interiorul cercului (punctele de intersecţie aflate chiar pe cerc nefiind luate în considerare).
Date de intrare
Fișierul de intrare cerc2.in conţine:
- pe prima linie două numere
NşiMdespărţite printr-un spaţiu, numere reprezentând numărul de puncte şi respectiv numărul de segmente; - pe următoarele
Mlinii, câte o pereche de numere distinctep1[1],p2[i]despărţite prin câte un spaţiu, numere reprezentând capetele câte unui segment.
Date de ieșire
Fișierul de ieșire cerc2.out va conține un singur număr P reprezentând numărul total de puncte de intersecţie formate în interiorul cercului. Dacă acest număr depăşeşte 999999, atunci se va scrie numărul format numai din ultimele sale 6 cifre.
Restricții și precizări
1 ≤ N ≤ 50000 ≤ M < 1250001 ≤ p1[i] < p2[i] ≤ N, numere naturale, oricareidin{1,…, M}- NU există perechi
p1[i] p2[i]identice.
Exemplu:
cerc2.in
5 6 1 2 1 3 1 4 2 4 3 5 4 5
cerc2.out
3
Explicație
S-au format în interiorul cercului 3 puncte de intersecţie (marcate prin cerculeţe pe figura de mai jos).
