77672024-01-11 09:17:30ZsBalazsAdószedőcpp17Accepted 30/30490ms17212 KiB
#include <bits/stdc++.h>

using namespace std;

int main() {
    int n, m, fo;
    cin >> n >> m >> fo;
    
    vector<vector<int>> graph(n);
    
    for (int i = 0; m > i; i++) {
        int a, b;
        cin >> a >> b;
        
        a--;
        b--;
        
        graph[a].push_back(b);
        graph[b].push_back(a);
    }
    
    vector<int> voltam(n, -1);
    // honnan, hova
    queue<pair<int, pair<int, int>>> sor;
    
    vector<pair<int, int>> felujit;
    
    sor.push({0, {fo-1, 0}});
    
    while (!sor.empty()) {
        auto current = sor.front();
        sor.pop();
        
        int honnan = current.first;
        int hova = current.second.first;
        int counter = current.second.second;
        
        if (voltam[hova] < counter && voltam[hova] != -1) continue;
        
        felujit.push_back({honnan, hova});
        
        if (voltam[hova] != counter) {
            for (int szom : graph[hova]) {
                sor.push({hova, {szom, counter+1}});
            }
        }
        
        voltam[hova] = counter;
    }
    
    cout << felujit.size()-1 << endl;
    
    for (int i = 1; felujit.size() > i; i++) {
        cout << felujit[i].first+1 << " " << felujit[i].second+1 << endl;
    }

    return 0;
}
SubtaskSumTestVerdictTimeMemory
base30/30
1Accepted0/03ms1808 KiB
2Accepted0/0358ms11736 KiB
3Accepted1/13ms2100 KiB
4Accepted1/13ms2100 KiB
5Accepted1/13ms2332 KiB
6Accepted1/13ms2540 KiB
7Accepted1/13ms2748 KiB
8Accepted1/13ms2872 KiB
9Accepted2/24ms3132 KiB
10Accepted2/27ms3376 KiB
11Accepted2/26ms3320 KiB
12Accepted2/226ms4464 KiB
13Accepted2/261ms5824 KiB
14Accepted2/2365ms11772 KiB
15Accepted1/1344ms16876 KiB
16Accepted1/1296ms13020 KiB
17Accepted2/2465ms16844 KiB
18Accepted2/2419ms16032 KiB
19Accepted2/2490ms16596 KiB
20Accepted2/2460ms17212 KiB
21Accepted2/2460ms17064 KiB