197822025-12-22 16:23:10szabel26Hírlánccpp17Futási hiba 0/80226ms17764 KiB
// hirlanc.cpp : This file contains the 'main' function. Program execution begins and ends there.
//

#include <iostream>
#include <vector>
using namespace std;

struct adat {
    vector<int>be;
    int sz, tav;
    bool lat, kor;
};

vector<adat>x, y;
vector<int>csp;

pair<int, int>sol;

int n, hossz, db, tav;

bool kor(int akt, int kezd)
{
    x[akt].lat = true;
    ++tav;
    if (x[x[akt].sz].kor)
    {
        x[akt].lat = false;
        x[akt].kor = false;
        return false;
    }
    else
    {
        if (x[akt].sz == kezd)
        {
            x[x[akt].sz].tav = tav + 1;
            x[akt].tav = tav;

            x[x[akt].sz].kor = true;
            x[akt].kor = true;
            return true;
        }
        else if (x[x[akt].sz].lat)
        {
            x[akt].lat = false;
            x[akt].kor = false;
            return false;
        }

        if (kor(x[akt].sz, kezd))
        {
            x[akt].tav = tav;
            x[akt].kor = true;
        }
        else
        {
            x[akt].lat = false;
            x[akt].kor = false;
            return false;
        }
    }

}

void bejar(int akt, int tav)
{
    x[akt].lat = 1;
    x[akt].tav = tav;
    for (auto& e : x[akt].be)
    {
        if (!x[e].lat && !x[e].kor)
        {
            bejar(e, tav + 1);
        }
    }
}

//void bejar(int akt)
//{
//    x[akt].lat = true;
//    y[akt].lat = true;
//    ++hossz;
//    if (x[x[akt].sz].lat == false)
//    {
//        bejar(x[akt].sz);
//    }
//    x[akt].lat = false;
//    return;
//}
//
//void kor(int akt, int kezd)
//{
//    y[akt].lat = true;
//    ++hossz;
//    if (y[y[akt].sz].lat == false)
//    {
//        kor(y[akt].sz, kezd);
//    }
//}

int main()
{
    cin >> n;

    x.resize(n + 1);
    //y.resize(n + 1, { 0,0,0 });
    int a = 0;
    for (int i = 1; i <= n; ++i)
    {
        cin >> a;
        x[i].sz = a;
        x[a].be.push_back(i);
    }

    for (int i = 1; i <= n; ++i)
    {
        tav = 0;
        if (!x[i].kor) kor(i, i);
    }

    for (int i = 1; i <= n; ++i)
    {
        if (x[i].kor) bejar(i, x[i].tav);
        if (x[i].tav > sol.second)
        {
            sol.first = i;
            sol.second = x[i].tav;
        }
    }

    /*for (int i = 1; i <= n; ++i)
    {
        cout << i << ": " << x[i].tav << endl;
    }*/

    //for (int i = 1; i <= n; ++i)
    //{
    //    if (x[i].be == 0)
    //    {
    //        csp.push_back(i);
    //    }
    //}

    //sol.first = 0;
    //sol.second = 0;
    //for (auto& e : csp)
    //{
    //    bejar(e);
    //    if (hossz > sol.second)
    //    {
    //        sol.first = e;
    //        sol.second = hossz;
    //    }
    //    hossz = 0;
    //}

    //for (int i = 1; i <= n; ++i)
    //{
    //    if (y[i].lat == 0) ++db;
    //}

    //for (int i = 1; i <= n; ++i)
    //{
    //    if (db <= sol.second)
    //    {
    //        break;
    //    }
    //    else
    //    {
    //        if (y[i].lat == false)
    //        {
    //            kor(i, i);
    //            if (hossz > sol.second)
    //            {
    //                sol.first = i;
    //                sol.second = hossz;
    //            }
    //            db += hossz;
    //            hossz = 0;
    //        }
    //    }
    //}
    cout << sol.first << " " << sol.second;
}

// Run program: Ctrl + F5 or Debug > Start Without Debugging menu
// Debug program: F5 or Debug > Start Debugging menu

// Tips for Getting Started: 
//   1. Use the Solution Explorer window to add/manage files
//   2. Use the Team Explorer window to connect to source control
//   3. Use the Output window to see build output and other messages
//   4. Use the Error List window to view errors
//   5. Go to Project > Add New Item to create new code files, or Project > Add Existing Item to add existing code files to the project
//   6. In the future, to open this project again, go to File > Open > Project and select the .sln file
RészfeladatÖsszpontTesztVerdiktIdőMemória
subtask10/0
1Futási hiba4ms500 KiB
subtask20/20
2Futási hiba4ms820 KiB
3Futási hiba4ms580 KiB
4Futási hiba4ms572 KiB
5Futási hiba4ms564 KiB
6Futási hiba4ms564 KiB
7Futási hiba4ms780 KiB
8Futási hiba4ms564 KiB
9Futási hiba4ms564 KiB
10Futási hiba4ms760 KiB
11Futási hiba4ms564 KiB
12Futási hiba4ms756 KiB
subtask30/18
13Futási hiba115ms14388 KiB
14Futási hiba107ms14400 KiB
15Futási hiba108ms14644 KiB
16Futási hiba119ms14636 KiB
17Futási hiba119ms15048 KiB
18Futási hiba135ms14900 KiB
19Futási hiba119ms14832 KiB
20Futási hiba136ms14900 KiB
21Futási hiba209ms17204 KiB
22Futási hiba226ms17764 KiB
subtask40/42
23Futási hiba4ms508 KiB
24Futási hiba4ms820 KiB
25Futási hiba4ms580 KiB
26Futási hiba4ms572 KiB
27Futási hiba4ms564 KiB
28Futási hiba4ms564 KiB
29Futási hiba4ms780 KiB
30Futási hiba4ms564 KiB
31Futási hiba4ms564 KiB
32Futási hiba4ms760 KiB
33Futási hiba4ms564 KiB
34Futási hiba4ms756 KiB
35Futási hiba115ms14388 KiB
36Futási hiba107ms14400 KiB
37Futási hiba108ms14644 KiB
38Futási hiba119ms14636 KiB
39Futási hiba119ms15048 KiB
40Futási hiba135ms14900 KiB
41Futási hiba119ms14832 KiB
42Futási hiba136ms14900 KiB
43Futási hiba209ms17204 KiB
44Futási hiba226ms17764 KiB
45Futási hiba111ms12340 KiB
46Futási hiba125ms12360 KiB
47Futási hiba127ms12188 KiB
48Futási hiba114ms12340 KiB
49Futási hiba119ms12344 KiB
50Futási hiba128ms12688 KiB
51Futási hiba142ms13100 KiB
52Futási hiba136ms13368 KiB
53Futási hiba157ms12852 KiB
54Futási hiba171ms13364 KiB