190062025-11-15 21:02:19gortomiPáros részgráfokcpp17Elfogadva 100/100953ms10928 KiB
#include <bits/stdc++.h>
using namespace std;
//#define int long long
using ll = long long;
using pii = pair<int, int>;
#define fi first
#define se second
int n, m;
int wr = 0;
int tr = 0;
vector<pii> v;
vector<int> p;
vector<int> s;
int get(int v)
{
    return p[v] == 0 ? v : get(p[v]);
}
void unio(int a, int b)
{
    a = get(a);
    b = get(b);
    if(a != b)
    {
        if(s[a] < s[b]) swap(a, b);
        v.push_back({b, a});
        p[b] = a;
        s[a] += s[b];
    }
    else
    {
        v.push_back({0, 0});
    }
}
void edge(pair<int, int> a)
{
    //tr++;
    unio(a.fi, a.se + n);
    unio(a.fi + n, a.se);
    if(get(a.fi + n) == get(a.fi))
    {
        wr++;
        v.push_back({-1, 0});
    }
}
void rollback()
{
    //tr--;
    for(int i = 0; i < 2; i++)
    {
        while(v.back().fi == -1)
        {
            v.pop_back();
            wr--;
        }
        auto [b, a] = v.back();
        v.pop_back();
        s[a] -= s[b];
        p[b] = 0;
    }
}
int l, r;
const int e = 20;
int bmax = -1;
vector<pair<int, int> > fr(e, {0, -1}), ba(e, {0, -1});
vector<pair<int, int> > a;
void ad()
{
    int siz = 0;
    while(fr[siz].fi != 0) siz++;
    int w = (1 << siz) - 1;
    for(int i = 0; i <= siz; i++)
    {
        fr[i] = {0, -1};
        if(ba[i].fi != 0) w += (1 << i);
    }

    for(int i = 0; i < w; i++)
    {
        rollback();
    }

    if(bmax < siz)
    {
        ba[siz] = {r - (1 << siz) + 1, r};
        bmax = siz;
    }
    else fr[siz] = {r - (1 << siz) + 1, r};

    for(int i = siz; i >= 0; i--)
    {
        for(int j = fr[i].fi; j <= fr[i].se; j++)
        {
            edge(a[j]);
        }
        for(int j = ba[i].fi; j <= ba[i].se; j++)
        {
            edge(a[j]);
        }
    }
}
void rem()
{
    int siz = 0;
    while(ba[siz].fi == 0) siz++;
    int w = 0;
    for(int i = 0; i < siz; i++)
    {
        if(fr[i].fi != 0) w += (1 << i);
        ba[i] = {l + (1 << i) - 1, l + (1 << (i + 1)) - 2};
    }
    w += (1 << siz);
    //cout << w << " " << tr << endl;
    for(int i = 0; i < w; i++) rollback();
    ba[siz] = {0, -1};
    if(bmax == siz)
    {
        if(fr[siz].fi != 0)
        {
            ba[siz] = fr[siz];
            fr[siz] = {0, -1};
        }
        else bmax--;
    }
    for(int i = siz - 1; i >= 0; i--)
    {
        for(int j = fr[i].fi; j <= fr[i].se; j++)
        {
            edge(a[j]);
        }
        for(int j = ba[i].fi; j <= ba[i].se; j++)
        {
            edge(a[j]);
        }
    }
}
void solve()
{
    cin >> n >> m;
    p.resize(2 * n + 1);
    s.resize(2 * n + 1, 1);
    a.resize(m + 1);
    for(int i = 1; i <= m; i++)
    {
        cin >> a[i].fi >> a[i].se;
    }
    l = 1;
    ll ans = 0;
    for(r = 1; r <= m; r++)
    {
        ad();

        /*
        cout << r << " " << tr << endl;
        for(int j = 0; j < e; j++)
        {
            if(fr[j].fi != 0) cout << fr[j].fi << " . " << fr[j].se << endl;
            if(ba[j].fi != 0) cout << ba[j].fi << " x " << ba[j].se << endl;
        }
        */

        while(wr > 0)
        {
            l++;
            rem();
            //cout << l << endl;
            //cout << "ok" << endl;
        }
        ans += r - l + 1;
        //cout << l << " " << r << endl;
    }
    cout << ans << "\n";
}
signed main()
{
    ios::sync_with_stdio(0);
    cin.tie(0);
    int te = 1;
    //cin >> te;
    while(te--) solve();
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
subtask10/0
1Elfogadva1ms316 KiB
2Elfogadva1ms316 KiB
subtask210/10
3Elfogadva1ms316 KiB
4Elfogadva1ms316 KiB
5Elfogadva1ms316 KiB
6Elfogadva1ms316 KiB
7Elfogadva1ms316 KiB
8Elfogadva1ms316 KiB
9Elfogadva1ms316 KiB
10Elfogadva1ms316 KiB
11Elfogadva1ms316 KiB
12Elfogadva1ms316 KiB
subtask37/7
13Elfogadva1ms316 KiB
14Elfogadva1ms316 KiB
15Elfogadva1ms316 KiB
16Elfogadva1ms316 KiB
17Elfogadva1ms316 KiB
18Elfogadva1ms316 KiB
19Elfogadva1ms316 KiB
20Elfogadva1ms316 KiB
21Elfogadva1ms316 KiB
22Elfogadva1ms316 KiB
23Elfogadva1ms368 KiB
24Elfogadva1ms316 KiB
25Elfogadva1ms316 KiB
26Elfogadva1ms316 KiB
27Elfogadva1ms316 KiB
28Elfogadva1ms316 KiB
29Elfogadva1ms316 KiB
30Elfogadva1ms316 KiB
31Elfogadva1ms316 KiB
32Elfogadva1ms316 KiB
subtask410/10
33Elfogadva1ms316 KiB
34Elfogadva1ms316 KiB
35Elfogadva1ms316 KiB
36Elfogadva1ms316 KiB
37Elfogadva1ms316 KiB
38Elfogadva1ms316 KiB
39Elfogadva1ms316 KiB
40Elfogadva1ms316 KiB
41Elfogadva1ms316 KiB
42Elfogadva1ms316 KiB
43Elfogadva1ms368 KiB
44Elfogadva1ms316 KiB
45Elfogadva1ms316 KiB
46Elfogadva1ms316 KiB
47Elfogadva1ms316 KiB
48Elfogadva1ms316 KiB
49Elfogadva1ms316 KiB
50Elfogadva1ms316 KiB
51Elfogadva1ms316 KiB
52Elfogadva1ms316 KiB
53Elfogadva2ms500 KiB
54Elfogadva2ms316 KiB
55Elfogadva1ms316 KiB
56Elfogadva2ms316 KiB
57Elfogadva2ms316 KiB
58Elfogadva2ms316 KiB
59Elfogadva2ms316 KiB
60Elfogadva1ms316 KiB
61Elfogadva1ms316 KiB
62Elfogadva1ms316 KiB
subtask520/20
63Elfogadva1ms316 KiB
64Elfogadva1ms316 KiB
65Elfogadva1ms316 KiB
66Elfogadva1ms316 KiB
67Elfogadva1ms316 KiB
68Elfogadva1ms316 KiB
69Elfogadva1ms316 KiB
70Elfogadva1ms316 KiB
71Elfogadva1ms316 KiB
72Elfogadva1ms316 KiB
73Elfogadva1ms368 KiB
74Elfogadva1ms316 KiB
75Elfogadva1ms316 KiB
76Elfogadva1ms316 KiB
77Elfogadva1ms316 KiB
78Elfogadva1ms316 KiB
79Elfogadva1ms316 KiB
80Elfogadva1ms316 KiB
81Elfogadva1ms316 KiB
82Elfogadva1ms316 KiB
83Elfogadva2ms500 KiB
84Elfogadva2ms316 KiB
85Elfogadva1ms316 KiB
86Elfogadva2ms316 KiB
87Elfogadva2ms316 KiB
88Elfogadva2ms316 KiB
89Elfogadva2ms316 KiB
90Elfogadva1ms316 KiB
91Elfogadva1ms316 KiB
92Elfogadva1ms316 KiB
93Elfogadva32ms1160 KiB
94Elfogadva41ms1508 KiB
95Elfogadva12ms1088 KiB
96Elfogadva43ms1480 KiB
97Elfogadva12ms1080 KiB
98Elfogadva37ms1696 KiB
99Elfogadva35ms1676 KiB
100Elfogadva32ms1784 KiB
101Elfogadva32ms1200 KiB
102Elfogadva39ms1712 KiB
subtask614/14
103Elfogadva1ms316 KiB
104Elfogadva1ms316 KiB
105Elfogadva1ms316 KiB
106Elfogadva1ms316 KiB
107Elfogadva1ms316 KiB
108Elfogadva1ms316 KiB
109Elfogadva1ms316 KiB
110Elfogadva1ms316 KiB
111Elfogadva1ms316 KiB
112Elfogadva1ms316 KiB
113Elfogadva1ms368 KiB
114Elfogadva1ms316 KiB
115Elfogadva1ms316 KiB
116Elfogadva1ms316 KiB
117Elfogadva1ms316 KiB
118Elfogadva1ms316 KiB
119Elfogadva1ms316 KiB
120Elfogadva1ms316 KiB
121Elfogadva1ms316 KiB
122Elfogadva1ms316 KiB
123Elfogadva2ms500 KiB
124Elfogadva2ms316 KiB
125Elfogadva1ms316 KiB
126Elfogadva2ms316 KiB
127Elfogadva2ms316 KiB
128Elfogadva2ms316 KiB
129Elfogadva2ms316 KiB
130Elfogadva1ms316 KiB
131Elfogadva1ms316 KiB
132Elfogadva1ms316 KiB
133Elfogadva32ms1160 KiB
134Elfogadva41ms1508 KiB
135Elfogadva12ms1088 KiB
136Elfogadva43ms1480 KiB
137Elfogadva12ms1080 KiB
138Elfogadva37ms1696 KiB
139Elfogadva35ms1676 KiB
140Elfogadva32ms1784 KiB
141Elfogadva32ms1200 KiB
142Elfogadva39ms1712 KiB
143Elfogadva70ms1880 KiB
144Elfogadva68ms2772 KiB
145Elfogadva72ms2996 KiB
146Elfogadva70ms1972 KiB
147Elfogadva24ms1844 KiB
148Elfogadva92ms2476 KiB
149Elfogadva85ms2996 KiB
150Elfogadva74ms3008 KiB
151Elfogadva93ms2484 KiB
152Elfogadva71ms1988 KiB
subtask720/20
153Elfogadva1ms316 KiB
154Elfogadva1ms316 KiB
155Elfogadva1ms316 KiB
156Elfogadva1ms316 KiB
157Elfogadva1ms316 KiB
158Elfogadva1ms316 KiB
159Elfogadva1ms316 KiB
160Elfogadva1ms316 KiB
161Elfogadva1ms316 KiB
162Elfogadva1ms316 KiB
163Elfogadva1ms368 KiB
164Elfogadva1ms316 KiB
165Elfogadva1ms316 KiB
166Elfogadva1ms316 KiB
167Elfogadva1ms316 KiB
168Elfogadva1ms316 KiB
169Elfogadva1ms316 KiB
170Elfogadva1ms316 KiB
171Elfogadva1ms316 KiB
172Elfogadva1ms316 KiB
173Elfogadva2ms500 KiB
174Elfogadva2ms316 KiB
175Elfogadva1ms316 KiB
176Elfogadva2ms316 KiB
177Elfogadva2ms316 KiB
178Elfogadva2ms316 KiB
179Elfogadva2ms316 KiB
180Elfogadva1ms316 KiB
181Elfogadva1ms316 KiB
182Elfogadva1ms316 KiB
183Elfogadva32ms1160 KiB
184Elfogadva41ms1508 KiB
185Elfogadva12ms1088 KiB
186Elfogadva43ms1480 KiB
187Elfogadva12ms1080 KiB
188Elfogadva37ms1696 KiB
189Elfogadva35ms1676 KiB
190Elfogadva32ms1784 KiB
191Elfogadva32ms1200 KiB
192Elfogadva39ms1712 KiB
193Elfogadva70ms1880 KiB
194Elfogadva68ms2772 KiB
195Elfogadva72ms2996 KiB
196Elfogadva70ms1972 KiB
197Elfogadva24ms1844 KiB
198Elfogadva92ms2476 KiB
199Elfogadva85ms2996 KiB
200Elfogadva74ms3008 KiB
201Elfogadva93ms2484 KiB
202Elfogadva71ms1988 KiB
203Elfogadva122ms3108 KiB
204Elfogadva119ms4968 KiB
205Elfogadva136ms4780 KiB
206Elfogadva122ms2992 KiB
207Elfogadva39ms2808 KiB
208Elfogadva170ms3752 KiB
209Elfogadva172ms4960 KiB
210Elfogadva146ms4960 KiB
211Elfogadva185ms3940 KiB
212Elfogadva123ms2992 KiB
subtask819/19
213Elfogadva1ms316 KiB
214Elfogadva1ms500 KiB
215Elfogadva1ms316 KiB
216Elfogadva1ms316 KiB
217Elfogadva1ms316 KiB
218Elfogadva1ms316 KiB
219Elfogadva1ms316 KiB
220Elfogadva1ms316 KiB
221Elfogadva1ms316 KiB
222Elfogadva1ms316 KiB
223Elfogadva1ms316 KiB
224Elfogadva1ms316 KiB
225Elfogadva1ms368 KiB
226Elfogadva1ms316 KiB
227Elfogadva1ms316 KiB
228Elfogadva1ms316 KiB
229Elfogadva1ms316 KiB
230Elfogadva1ms316 KiB
231Elfogadva1ms316 KiB
232Elfogadva1ms316 KiB
233Elfogadva1ms316 KiB
234Elfogadva1ms316 KiB
235Elfogadva2ms500 KiB
236Elfogadva2ms316 KiB
237Elfogadva1ms316 KiB
238Elfogadva2ms316 KiB
239Elfogadva2ms316 KiB
240Elfogadva2ms316 KiB
241Elfogadva2ms316 KiB
242Elfogadva1ms316 KiB
243Elfogadva1ms316 KiB
244Elfogadva1ms316 KiB
245Elfogadva32ms1160 KiB
246Elfogadva41ms1508 KiB
247Elfogadva12ms1088 KiB
248Elfogadva43ms1480 KiB
249Elfogadva12ms1080 KiB
250Elfogadva37ms1696 KiB
251Elfogadva35ms1676 KiB
252Elfogadva32ms1784 KiB
253Elfogadva32ms1200 KiB
254Elfogadva39ms1712 KiB
255Elfogadva70ms1880 KiB
256Elfogadva68ms2772 KiB
257Elfogadva72ms2996 KiB
258Elfogadva70ms1972 KiB
259Elfogadva24ms1844 KiB
260Elfogadva92ms2476 KiB
261Elfogadva85ms2996 KiB
262Elfogadva74ms3008 KiB
263Elfogadva93ms2484 KiB
264Elfogadva71ms1988 KiB
265Elfogadva122ms3108 KiB
266Elfogadva119ms4968 KiB
267Elfogadva136ms4780 KiB
268Elfogadva122ms2992 KiB
269Elfogadva39ms2808 KiB
270Elfogadva170ms3752 KiB
271Elfogadva172ms4960 KiB
272Elfogadva146ms4960 KiB
273Elfogadva185ms3940 KiB
274Elfogadva123ms2992 KiB
275Elfogadva549ms10912 KiB
276Elfogadva790ms10920 KiB
277Elfogadva546ms10928 KiB
278Elfogadva792ms10908 KiB
279Elfogadva953ms8876 KiB
280Elfogadva485ms8792 KiB
281Elfogadva782ms10920 KiB
282Elfogadva791ms10916 KiB
283Elfogadva714ms10916 KiB
284Elfogadva544ms10920 KiB