190042025-11-15 20:29:41gortomiPáros részgráfokcpp17Időlimit túllépés 61/1002.601s8876 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;
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(int a, int b)
{
    unio(a, b + n);
    unio(a + n, b);
    if(get(a + n) == get(a))
    {
        wr++;
        v.push_back({-1, 0});
    }
}
void rollback()
{
    while(v.back().fi == -1)
    {
        v.pop_back();
        wr--;
    }
    auto [b, a] = v.back();
    v.pop_back();
    s[a] -= s[b];
    p[b] = 0;
}
void solve()
{
    cin >> n >> m;
    p.resize(2 * n + 1);
    s.resize(2 * n + 1, 1);
    vector<pair<int, int> > a(m + 1);
    for(int i = 1; i <= m; i++)
    {
        cin >> a[i].fi >> a[i].se;
    }
    const int SQRT = sqrt(m);
    int l = 1;
    ll ans = 0;
    for(int i = 1; i <= m; i++)
    {
        int nxt = (l - 1) / SQRT + 1;
        nxt *= SQRT;
        if(i % SQRT == 0 && l <= i - SQRT)
        {
            for(int j = i - SQRT + 1; j <= i; j++)
            {
                edge(a[j].fi, a[j].se);
            }
        }
        int bef = i / SQRT;
        bef *= SQRT;
        if(bef >= nxt)
        {
            for(int j = bef + 1; j <= i; j++)
            {
                edge(a[j].fi, a[j].se);
            }
            for(int j = nxt; j >= l; j--)
            {
                edge(a[j].fi, a[j].se);
            }
            while(wr > 0)
            {
                while(wr > 0 && l <= nxt)
                {
                    rollback();
                    rollback();
                    l++;
                }
                if(l <= nxt) break;
                for(int j = l; j <= i; j++)
                {
                    rollback();
                    rollback();
                }
                nxt += SQRT;
                if(nxt > bef) break;
                for(int j = nxt + 1; j <= i; j++)
                {
                    edge(a[j].fi, a[j].se);
                }
                for(int j = nxt; j >= l; j--)
                {
                    edge(a[j].fi, a[j].se);
                }
            }
            if(nxt <= bef)
            {
                for(int j = l; j <= nxt; j++)
                {
                    rollback();
                    rollback();
                }
                for(int j = bef + 1; j <= i; j++)
                {
                    rollback();
                    rollback();
                }
            }
        }
        if(bef < nxt)
        {
            for(int j = i; j >= l; j--)
            {
                edge(a[j].fi, a[j].se);
                if(wr > 0)
                {
                    rollback();
                    rollback();
                    l = j + 1;
                    break;
                }
            }
            for(int j = l; j <= i; j++)
            {
                rollback();
                rollback();
            }
        }
        ans += i - l + 1;
    }
    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
2Elfogadva1ms508 KiB
subtask210/10
3Elfogadva1ms316 KiB
4Elfogadva1ms316 KiB
5Elfogadva1ms316 KiB
6Elfogadva1ms316 KiB
7Elfogadva1ms500 KiB
8Elfogadva1ms316 KiB
9Elfogadva1ms316 KiB
10Elfogadva1ms316 KiB
11Elfogadva1ms316 KiB
12Elfogadva1ms316 KiB
subtask37/7
13Elfogadva1ms316 KiB
14Elfogadva1ms316 KiB
15Elfogadva1ms316 KiB
16Elfogadva1ms316 KiB
17Elfogadva1ms500 KiB
18Elfogadva1ms316 KiB
19Elfogadva1ms316 KiB
20Elfogadva1ms316 KiB
21Elfogadva1ms316 KiB
22Elfogadva1ms316 KiB
23Elfogadva1ms316 KiB
24Elfogadva1ms316 KiB
25Elfogadva1ms420 KiB
26Elfogadva1ms316 KiB
27Elfogadva1ms316 KiB
28Elfogadva1ms316 KiB
29Elfogadva1ms396 KiB
30Elfogadva1ms508 KiB
31Elfogadva1ms316 KiB
32Elfogadva1ms316 KiB
subtask410/10
33Elfogadva1ms316 KiB
34Elfogadva1ms316 KiB
35Elfogadva1ms316 KiB
36Elfogadva1ms316 KiB
37Elfogadva1ms500 KiB
38Elfogadva1ms316 KiB
39Elfogadva1ms316 KiB
40Elfogadva1ms316 KiB
41Elfogadva1ms316 KiB
42Elfogadva1ms316 KiB
43Elfogadva1ms316 KiB
44Elfogadva1ms316 KiB
45Elfogadva1ms420 KiB
46Elfogadva1ms316 KiB
47Elfogadva1ms316 KiB
48Elfogadva1ms316 KiB
49Elfogadva1ms396 KiB
50Elfogadva1ms508 KiB
51Elfogadva1ms316 KiB
52Elfogadva1ms316 KiB
53Elfogadva3ms316 KiB
54Elfogadva3ms500 KiB
55Elfogadva1ms512 KiB
56Elfogadva3ms316 KiB
57Elfogadva3ms508 KiB
58Elfogadva3ms468 KiB
59Elfogadva3ms456 KiB
60Elfogadva1ms316 KiB
61Elfogadva1ms344 KiB
62Elfogadva1ms316 KiB
subtask520/20
63Elfogadva1ms316 KiB
64Elfogadva1ms316 KiB
65Elfogadva1ms316 KiB
66Elfogadva1ms316 KiB
67Elfogadva1ms500 KiB
68Elfogadva1ms316 KiB
69Elfogadva1ms316 KiB
70Elfogadva1ms316 KiB
71Elfogadva1ms316 KiB
72Elfogadva1ms316 KiB
73Elfogadva1ms316 KiB
74Elfogadva1ms316 KiB
75Elfogadva1ms420 KiB
76Elfogadva1ms316 KiB
77Elfogadva1ms316 KiB
78Elfogadva1ms316 KiB
79Elfogadva1ms396 KiB
80Elfogadva1ms508 KiB
81Elfogadva1ms316 KiB
82Elfogadva1ms316 KiB
83Elfogadva3ms316 KiB
84Elfogadva3ms500 KiB
85Elfogadva1ms512 KiB
86Elfogadva3ms316 KiB
87Elfogadva3ms508 KiB
88Elfogadva3ms468 KiB
89Elfogadva3ms456 KiB
90Elfogadva1ms316 KiB
91Elfogadva1ms344 KiB
92Elfogadva1ms316 KiB
93Elfogadva310ms1156 KiB
94Elfogadva337ms1456 KiB
95Elfogadva10ms956 KiB
96Elfogadva367ms1504 KiB
97Elfogadva10ms1076 KiB
98Elfogadva393ms1720 KiB
99Elfogadva305ms1716 KiB
100Elfogadva305ms1716 KiB
101Elfogadva312ms1200 KiB
102Elfogadva400ms1544 KiB
subtask614/14
103Elfogadva1ms316 KiB
104Elfogadva1ms316 KiB
105Elfogadva1ms316 KiB
106Elfogadva1ms316 KiB
107Elfogadva1ms500 KiB
108Elfogadva1ms316 KiB
109Elfogadva1ms316 KiB
110Elfogadva1ms316 KiB
111Elfogadva1ms316 KiB
112Elfogadva1ms316 KiB
113Elfogadva1ms316 KiB
114Elfogadva1ms316 KiB
115Elfogadva1ms420 KiB
116Elfogadva1ms316 KiB
117Elfogadva1ms316 KiB
118Elfogadva1ms316 KiB
119Elfogadva1ms396 KiB
120Elfogadva1ms508 KiB
121Elfogadva1ms316 KiB
122Elfogadva1ms316 KiB
123Elfogadva3ms316 KiB
124Elfogadva3ms500 KiB
125Elfogadva1ms512 KiB
126Elfogadva3ms316 KiB
127Elfogadva3ms508 KiB
128Elfogadva3ms468 KiB
129Elfogadva3ms456 KiB
130Elfogadva1ms316 KiB
131Elfogadva1ms344 KiB
132Elfogadva1ms316 KiB
133Elfogadva310ms1156 KiB
134Elfogadva337ms1456 KiB
135Elfogadva10ms956 KiB
136Elfogadva367ms1504 KiB
137Elfogadva10ms1076 KiB
138Elfogadva393ms1720 KiB
139Elfogadva305ms1716 KiB
140Elfogadva305ms1716 KiB
141Elfogadva312ms1200 KiB
142Elfogadva400ms1544 KiB
143Elfogadva867ms1968 KiB
144Elfogadva856ms2992 KiB
145Elfogadva968ms2992 KiB
146Elfogadva869ms1972 KiB
147Elfogadva21ms1852 KiB
148Elfogadva1.014s2352 KiB
149Elfogadva1.195s2936 KiB
150Elfogadva1.014s2992 KiB
151Elfogadva1.008s2484 KiB
152Elfogadva873ms1972 KiB
subtask70/20
153Elfogadva1ms316 KiB
154Elfogadva1ms316 KiB
155Elfogadva1ms316 KiB
156Elfogadva1ms316 KiB
157Elfogadva1ms500 KiB
158Elfogadva1ms316 KiB
159Elfogadva1ms316 KiB
160Elfogadva1ms316 KiB
161Elfogadva1ms316 KiB
162Elfogadva1ms316 KiB
163Elfogadva1ms316 KiB
164Elfogadva1ms316 KiB
165Elfogadva1ms420 KiB
166Elfogadva1ms316 KiB
167Elfogadva1ms316 KiB
168Elfogadva1ms316 KiB
169Elfogadva1ms396 KiB
170Elfogadva1ms508 KiB
171Elfogadva1ms316 KiB
172Elfogadva1ms316 KiB
173Elfogadva3ms316 KiB
174Elfogadva3ms500 KiB
175Elfogadva1ms512 KiB
176Elfogadva3ms316 KiB
177Elfogadva3ms508 KiB
178Elfogadva3ms468 KiB
179Elfogadva3ms456 KiB
180Elfogadva1ms316 KiB
181Elfogadva1ms344 KiB
182Elfogadva1ms316 KiB
183Elfogadva310ms1156 KiB
184Elfogadva337ms1456 KiB
185Elfogadva10ms956 KiB
186Elfogadva367ms1504 KiB
187Elfogadva10ms1076 KiB
188Elfogadva393ms1720 KiB
189Elfogadva305ms1716 KiB
190Elfogadva305ms1716 KiB
191Elfogadva312ms1200 KiB
192Elfogadva400ms1544 KiB
193Elfogadva867ms1968 KiB
194Elfogadva856ms2992 KiB
195Elfogadva968ms2992 KiB
196Elfogadva869ms1972 KiB
197Elfogadva21ms1852 KiB
198Elfogadva1.014s2352 KiB
199Elfogadva1.195s2936 KiB
200Elfogadva1.014s2992 KiB
201Elfogadva1.008s2484 KiB
202Elfogadva873ms1972 KiB
203Elfogadva1.865s2992 KiB
204Elfogadva1.842s4780 KiB
205Elfogadva2.096s4780 KiB
206Elfogadva1.866s3000 KiB
207Elfogadva35ms2612 KiB
208Elfogadva2.221s3932 KiB
209Időlimit túllépés2.599s4780 KiB
210Elfogadva2.476s4780 KiB
211Elfogadva2.448s3760 KiB
212Elfogadva1.866s2992 KiB
subtask80/19
213Elfogadva1ms316 KiB
214Elfogadva1ms508 KiB
215Elfogadva1ms316 KiB
216Elfogadva1ms316 KiB
217Elfogadva1ms316 KiB
218Elfogadva1ms316 KiB
219Elfogadva1ms500 KiB
220Elfogadva1ms316 KiB
221Elfogadva1ms316 KiB
222Elfogadva1ms316 KiB
223Elfogadva1ms316 KiB
224Elfogadva1ms316 KiB
225Elfogadva1ms316 KiB
226Elfogadva1ms316 KiB
227Elfogadva1ms420 KiB
228Elfogadva1ms316 KiB
229Elfogadva1ms316 KiB
230Elfogadva1ms316 KiB
231Elfogadva1ms396 KiB
232Elfogadva1ms508 KiB
233Elfogadva1ms316 KiB
234Elfogadva1ms316 KiB
235Elfogadva3ms316 KiB
236Elfogadva3ms500 KiB
237Elfogadva1ms512 KiB
238Elfogadva3ms316 KiB
239Elfogadva3ms508 KiB
240Elfogadva3ms468 KiB
241Elfogadva3ms456 KiB
242Elfogadva1ms316 KiB
243Elfogadva1ms344 KiB
244Elfogadva1ms316 KiB
245Elfogadva310ms1156 KiB
246Elfogadva337ms1456 KiB
247Elfogadva10ms956 KiB
248Elfogadva367ms1504 KiB
249Elfogadva10ms1076 KiB
250Elfogadva393ms1720 KiB
251Elfogadva305ms1716 KiB
252Elfogadva305ms1716 KiB
253Elfogadva312ms1200 KiB
254Elfogadva400ms1544 KiB
255Elfogadva867ms1968 KiB
256Elfogadva856ms2992 KiB
257Elfogadva968ms2992 KiB
258Elfogadva869ms1972 KiB
259Elfogadva21ms1852 KiB
260Elfogadva1.014s2352 KiB
261Elfogadva1.195s2936 KiB
262Elfogadva1.014s2992 KiB
263Elfogadva1.008s2484 KiB
264Elfogadva873ms1972 KiB
265Elfogadva1.865s2992 KiB
266Elfogadva1.842s4780 KiB
267Elfogadva2.096s4780 KiB
268Elfogadva1.866s3000 KiB
269Elfogadva35ms2612 KiB
270Elfogadva2.221s3932 KiB
271Időlimit túllépés2.599s4780 KiB
272Elfogadva2.476s4780 KiB
273Elfogadva2.448s3760 KiB
274Elfogadva1.866s2992 KiB
275Időlimit túllépés2.584s8876 KiB
276Időlimit túllépés2.584s7856 KiB
277Időlimit túllépés2.601s8872 KiB
278Időlimit túllépés2.601s7852 KiB
279Időlimit túllépés2.585s7828 KiB
280Időlimit túllépés2.585s8872 KiB
281Időlimit túllépés2.599s7696 KiB
282Időlimit túllépés2.599s7856 KiB
283Időlimit túllépés2.579s8876 KiB
284Időlimit túllépés2.579s8876 KiB