148242025-02-03 17:37:10csdavidKaktuszgráfcpp17Accepted 50/502ms640 KiB
#include <iostream>
#include <queue>
#include <vector>
using namespace std;
vector<int> csucs[1500];
int d[1500], maxi=0;

void dfs(int x){
    for(auto& it:csucs[x]){
        if(d[it]==-1){
            d[it]=d[x]+1;
            dfs(it);
        }
        else if(d[it]-d[x]>1){
            maxi=max(maxi, d[it]-d[x]+1);
        }
    }
}

int main()
{
    int n, m, x, y;
    cin >> n >> m;
    fill(d, d+1500, -1);
    for(int i=0; i<m; i++){
        cin >> x >> y;
        csucs[x-1].push_back(y-1);
        csucs[y-1].push_back(x-1);
    }
    d[0]=0;
    dfs(0);
    cout << maxi;
    return 0;
}

SubtaskSumTestVerdictTimeMemory
base50/50
1Accepted0/01ms316 KiB
2Accepted0/01ms512 KiB
3Accepted2/22ms316 KiB
4Accepted2/22ms316 KiB
5Accepted2/22ms508 KiB
6Accepted2/22ms316 KiB
7Accepted2/22ms316 KiB
8Accepted2/22ms640 KiB
9Accepted2/22ms316 KiB
10Accepted2/22ms500 KiB
11Accepted2/22ms316 KiB
12Accepted2/22ms508 KiB
13Accepted2/22ms316 KiB
14Accepted2/22ms316 KiB
15Accepted2/22ms316 KiB
16Accepted2/22ms316 KiB
17Accepted2/22ms316 KiB
18Accepted2/22ms316 KiB
19Accepted3/32ms316 KiB
20Accepted3/32ms316 KiB
21Accepted3/32ms316 KiB
22Accepted3/32ms396 KiB
23Accepted3/32ms316 KiB
24Accepted3/32ms368 KiB