162882025-04-20 12:11:58horkaSzimmetrikus sorozatcpp17Elfogadva 100/100428ms26164 KiB
#include <bits/stdc++.h>
using namespace std;
#define pb push_back
#define sz(x) (int)x.size()
map<int, vector<int>> adj;
vector<array<int, 2>> ans;
void add(int a, int b)
{
    if(a==b) return;
    ans.pb({max(a,b),min(a,b)});
}
set<int> vis;
vector<int> curr;
int mini;
void dfs(int cs)
{
    vis.insert(cs);
    curr.push_back(cs);
    mini=min(mini,cs);
    for(int &i:adj[cs])
        if(!vis.count(i)) dfs(i);
}
int main()
{
    ios_base::sync_with_stdio(0);cin.tie(0);cout.tie(0);
    int n; cin>>n;
    vector<int> v(n+1);
    for(int i=1; i<=n; i++)
        cin>>v[i];
    for(int i=1; i<=n/2; i++)
        if(v[i]!=v[n-i+1])
    {
        adj[v[i]].pb(v[n-i+1]);
        adj[v[n-i+1]].pb(v[i]);
    }
    for(int i=1; i<=n; i++)
        if(!vis.count(v[i]))
    {
        mini=1e9+10;
        curr.clear();
        dfs(v[i]);
        for(int &x:curr)
            add(x,mini);
    }
    cout<<sz(ans)<<"\n";
    for(auto [a,b]:ans)
        cout<<a<<" "<<b<<"\n";
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
subtask10/0
1Elfogadva1ms316 KiB
2Elfogadva135ms10036 KiB
subtask29/9
3Elfogadva2ms316 KiB
4Elfogadva1ms316 KiB
5Elfogadva1ms316 KiB
6Elfogadva1ms316 KiB
7Elfogadva1ms316 KiB
subtask314/14
8Elfogadva1ms316 KiB
9Elfogadva1ms316 KiB
10Elfogadva1ms316 KiB
11Elfogadva1ms316 KiB
12Elfogadva1ms316 KiB
13Elfogadva1ms316 KiB
subtask425/25
14Elfogadva1ms328 KiB
15Elfogadva2ms316 KiB
16Elfogadva3ms564 KiB
17Elfogadva4ms588 KiB
18Elfogadva3ms564 KiB
19Elfogadva3ms564 KiB
20Elfogadva3ms564 KiB
21Elfogadva2ms576 KiB
subtask522/22
22Elfogadva209ms18936 KiB
23Elfogadva203ms26156 KiB
24Elfogadva221ms26164 KiB
25Elfogadva211ms18848 KiB
26Elfogadva187ms18856 KiB
27Elfogadva174ms25704 KiB
28Elfogadva170ms25704 KiB
29Elfogadva174ms18860 KiB
30Elfogadva166ms18860 KiB
31Elfogadva164ms25920 KiB
32Elfogadva153ms25896 KiB
33Elfogadva156ms18860 KiB
34Elfogadva162ms18860 KiB
35Elfogadva177ms22468 KiB
36Elfogadva165ms24144 KiB
37Elfogadva174ms18984 KiB
subtask630/30
38Elfogadva1ms508 KiB
39Elfogadva143ms10032 KiB
40Elfogadva2ms316 KiB
41Elfogadva1ms316 KiB
42Elfogadva1ms316 KiB
43Elfogadva1ms316 KiB
44Elfogadva1ms316 KiB
45Elfogadva1ms316 KiB
46Elfogadva1ms316 KiB
47Elfogadva1ms316 KiB
48Elfogadva1ms316 KiB
49Elfogadva1ms316 KiB
50Elfogadva1ms316 KiB
51Elfogadva1ms328 KiB
52Elfogadva2ms316 KiB
53Elfogadva3ms564 KiB
54Elfogadva4ms588 KiB
55Elfogadva3ms564 KiB
56Elfogadva3ms564 KiB
57Elfogadva3ms564 KiB
58Elfogadva2ms576 KiB
59Elfogadva209ms18936 KiB
60Elfogadva203ms26156 KiB
61Elfogadva221ms26164 KiB
62Elfogadva211ms18848 KiB
63Elfogadva187ms18856 KiB
64Elfogadva174ms25704 KiB
65Elfogadva170ms25704 KiB
66Elfogadva174ms18860 KiB
67Elfogadva166ms18860 KiB
68Elfogadva164ms25920 KiB
69Elfogadva153ms25896 KiB
70Elfogadva156ms18860 KiB
71Elfogadva162ms18860 KiB
72Elfogadva177ms22468 KiB
73Elfogadva165ms24144 KiB
74Elfogadva174ms18984 KiB
75Elfogadva418ms24228 KiB
76Elfogadva246ms13356 KiB
77Elfogadva64ms5888 KiB
78Elfogadva250ms13352 KiB
79Elfogadva150ms7104 KiB
80Elfogadva196ms14388 KiB
81Elfogadva173ms14384 KiB
82Elfogadva216ms14388 KiB
83Elfogadva428ms25568 KiB
84Elfogadva71ms6576 KiB
85Elfogadva158ms7876 KiB
86Elfogadva190ms15668 KiB
87Elfogadva190ms15668 KiB
88Elfogadva190ms15676 KiB
89Elfogadva165ms15668 KiB