190052025-11-15 20:55:31gortomiPáros részgráfokcpp17Elfogadva 100/1001.171s21268 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;
    int 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
23Elfogadva1ms508 KiB
24Elfogadva1ms316 KiB
25Elfogadva1ms316 KiB
26Elfogadva1ms316 KiB
27Elfogadva1ms316 KiB
28Elfogadva1ms316 KiB
29Elfogadva1ms508 KiB
30Elfogadva1ms316 KiB
31Elfogadva1ms316 KiB
32Elfogadva1ms500 KiB
subtask410/10
33Elfogadva1ms316 KiB
34Elfogadva1ms316 KiB
35Elfogadva1ms316 KiB
36Elfogadva1ms316 KiB
37Elfogadva1ms316 KiB
38Elfogadva1ms316 KiB
39Elfogadva1ms316 KiB
40Elfogadva1ms316 KiB
41Elfogadva1ms316 KiB
42Elfogadva1ms316 KiB
43Elfogadva1ms508 KiB
44Elfogadva1ms316 KiB
45Elfogadva1ms316 KiB
46Elfogadva1ms316 KiB
47Elfogadva1ms316 KiB
48Elfogadva1ms316 KiB
49Elfogadva1ms508 KiB
50Elfogadva1ms316 KiB
51Elfogadva1ms316 KiB
52Elfogadva1ms500 KiB
53Elfogadva2ms520 KiB
54Elfogadva2ms316 KiB
55Elfogadva1ms316 KiB
56Elfogadva2ms316 KiB
57Elfogadva2ms316 KiB
58Elfogadva2ms316 KiB
59Elfogadva2ms316 KiB
60Elfogadva2ms540 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
73Elfogadva1ms508 KiB
74Elfogadva1ms316 KiB
75Elfogadva1ms316 KiB
76Elfogadva1ms316 KiB
77Elfogadva1ms316 KiB
78Elfogadva1ms316 KiB
79Elfogadva1ms508 KiB
80Elfogadva1ms316 KiB
81Elfogadva1ms316 KiB
82Elfogadva1ms500 KiB
83Elfogadva2ms520 KiB
84Elfogadva2ms316 KiB
85Elfogadva1ms316 KiB
86Elfogadva2ms316 KiB
87Elfogadva2ms316 KiB
88Elfogadva2ms316 KiB
89Elfogadva2ms316 KiB
90Elfogadva2ms540 KiB
91Elfogadva1ms316 KiB
92Elfogadva1ms316 KiB
93Elfogadva32ms1920 KiB
94Elfogadva45ms2444 KiB
95Elfogadva13ms1604 KiB
96Elfogadva46ms2440 KiB
97Elfogadva12ms1844 KiB
98Elfogadva37ms2944 KiB
99Elfogadva32ms2792 KiB
100Elfogadva32ms2992 KiB
101Elfogadva32ms2028 KiB
102Elfogadva39ms2804 KiB
subtask614/14
103Elfogadva1ms316 KiB
104Elfogadva1ms316 KiB
105Elfogadva1ms316 KiB
106Elfogadva1ms316 KiB
107Elfogadva1ms316 KiB
108Elfogadva1ms316 KiB
109Elfogadva1ms316 KiB
110Elfogadva1ms316 KiB
111Elfogadva1ms316 KiB
112Elfogadva1ms316 KiB
113Elfogadva1ms508 KiB
114Elfogadva1ms316 KiB
115Elfogadva1ms316 KiB
116Elfogadva1ms316 KiB
117Elfogadva1ms316 KiB
118Elfogadva1ms316 KiB
119Elfogadva1ms508 KiB
120Elfogadva1ms316 KiB
121Elfogadva1ms316 KiB
122Elfogadva1ms500 KiB
123Elfogadva2ms520 KiB
124Elfogadva2ms316 KiB
125Elfogadva1ms316 KiB
126Elfogadva2ms316 KiB
127Elfogadva2ms316 KiB
128Elfogadva2ms316 KiB
129Elfogadva2ms316 KiB
130Elfogadva2ms540 KiB
131Elfogadva1ms316 KiB
132Elfogadva1ms316 KiB
133Elfogadva32ms1920 KiB
134Elfogadva45ms2444 KiB
135Elfogadva13ms1604 KiB
136Elfogadva46ms2440 KiB
137Elfogadva12ms1844 KiB
138Elfogadva37ms2944 KiB
139Elfogadva32ms2792 KiB
140Elfogadva32ms2992 KiB
141Elfogadva32ms2028 KiB
142Elfogadva39ms2804 KiB
143Elfogadva68ms3468 KiB
144Elfogadva68ms5292 KiB
145Elfogadva75ms5292 KiB
146Elfogadva68ms3256 KiB
147Elfogadva24ms3132 KiB
148Elfogadva98ms4256 KiB
149Elfogadva90ms5428 KiB
150Elfogadva76ms5328 KiB
151Elfogadva101ms4272 KiB
152Elfogadva68ms3664 KiB
subtask720/20
153Elfogadva1ms316 KiB
154Elfogadva1ms316 KiB
155Elfogadva1ms316 KiB
156Elfogadva1ms316 KiB
157Elfogadva1ms316 KiB
158Elfogadva1ms316 KiB
159Elfogadva1ms316 KiB
160Elfogadva1ms316 KiB
161Elfogadva1ms316 KiB
162Elfogadva1ms316 KiB
163Elfogadva1ms508 KiB
164Elfogadva1ms316 KiB
165Elfogadva1ms316 KiB
166Elfogadva1ms316 KiB
167Elfogadva1ms316 KiB
168Elfogadva1ms316 KiB
169Elfogadva1ms508 KiB
170Elfogadva1ms316 KiB
171Elfogadva1ms316 KiB
172Elfogadva1ms500 KiB
173Elfogadva2ms520 KiB
174Elfogadva2ms316 KiB
175Elfogadva1ms316 KiB
176Elfogadva2ms316 KiB
177Elfogadva2ms316 KiB
178Elfogadva2ms316 KiB
179Elfogadva2ms316 KiB
180Elfogadva2ms540 KiB
181Elfogadva1ms316 KiB
182Elfogadva1ms316 KiB
183Elfogadva32ms1920 KiB
184Elfogadva45ms2444 KiB
185Elfogadva13ms1604 KiB
186Elfogadva46ms2440 KiB
187Elfogadva12ms1844 KiB
188Elfogadva37ms2944 KiB
189Elfogadva32ms2792 KiB
190Elfogadva32ms2992 KiB
191Elfogadva32ms2028 KiB
192Elfogadva39ms2804 KiB
193Elfogadva68ms3468 KiB
194Elfogadva68ms5292 KiB
195Elfogadva75ms5292 KiB
196Elfogadva68ms3256 KiB
197Elfogadva24ms3132 KiB
198Elfogadva98ms4256 KiB
199Elfogadva90ms5428 KiB
200Elfogadva76ms5328 KiB
201Elfogadva101ms4272 KiB
202Elfogadva68ms3664 KiB
203Elfogadva119ms5548 KiB
204Elfogadva119ms9128 KiB
205Elfogadva144ms9344 KiB
206Elfogadva119ms5544 KiB
207Elfogadva37ms4916 KiB
208Elfogadva185ms7084 KiB
209Elfogadva192ms9128 KiB
210Elfogadva158ms9356 KiB
211Elfogadva200ms7084 KiB
212Elfogadva122ms5548 KiB
subtask819/19
213Elfogadva1ms500 KiB
214Elfogadva1ms316 KiB
215Elfogadva1ms316 KiB
216Elfogadva1ms316 KiB
217Elfogadva1ms316 KiB
218Elfogadva1ms316 KiB
219Elfogadva1ms316 KiB
220Elfogadva1ms316 KiB
221Elfogadva1ms316 KiB
222Elfogadva1ms316 KiB
223Elfogadva1ms316 KiB
224Elfogadva1ms316 KiB
225Elfogadva1ms508 KiB
226Elfogadva1ms316 KiB
227Elfogadva1ms316 KiB
228Elfogadva1ms316 KiB
229Elfogadva1ms316 KiB
230Elfogadva1ms316 KiB
231Elfogadva1ms508 KiB
232Elfogadva1ms316 KiB
233Elfogadva1ms316 KiB
234Elfogadva1ms500 KiB
235Elfogadva2ms520 KiB
236Elfogadva2ms316 KiB
237Elfogadva1ms316 KiB
238Elfogadva2ms316 KiB
239Elfogadva2ms316 KiB
240Elfogadva2ms316 KiB
241Elfogadva2ms316 KiB
242Elfogadva2ms540 KiB
243Elfogadva1ms316 KiB
244Elfogadva1ms316 KiB
245Elfogadva32ms1920 KiB
246Elfogadva45ms2444 KiB
247Elfogadva13ms1604 KiB
248Elfogadva46ms2440 KiB
249Elfogadva12ms1844 KiB
250Elfogadva37ms2944 KiB
251Elfogadva32ms2792 KiB
252Elfogadva32ms2992 KiB
253Elfogadva32ms2028 KiB
254Elfogadva39ms2804 KiB
255Elfogadva68ms3468 KiB
256Elfogadva68ms5292 KiB
257Elfogadva75ms5292 KiB
258Elfogadva68ms3256 KiB
259Elfogadva24ms3132 KiB
260Elfogadva98ms4256 KiB
261Elfogadva90ms5428 KiB
262Elfogadva76ms5328 KiB
263Elfogadva101ms4272 KiB
264Elfogadva68ms3664 KiB
265Elfogadva119ms5548 KiB
266Elfogadva119ms9128 KiB
267Elfogadva144ms9344 KiB
268Elfogadva119ms5544 KiB
269Elfogadva37ms4916 KiB
270Elfogadva185ms7084 KiB
271Elfogadva192ms9128 KiB
272Elfogadva158ms9356 KiB
273Elfogadva200ms7084 KiB
274Elfogadva122ms5548 KiB
275Elfogadva541ms21152 KiB
276Elfogadva926ms21156 KiB
277Elfogadva541ms21268 KiB
278Elfogadva926ms21268 KiB
279Elfogadva1.171s17064 KiB
280Elfogadva620ms17064 KiB
281Elfogadva907ms21264 KiB
282Elfogadva925ms21124 KiB
283Elfogadva795ms21152 KiB
284Elfogadva542ms21152 KiB