City and Flood

Fatland is a town that started with N distinct empires, namely empires 1, 2, ..., N. But over time, the armies of some of these empires have taken over other ones. Each takeover occurred when the army of empire i invaded empire j. After each invasion, all of empire j became part of empire i, and empire j was renamed as empire i.

Empire Huang, leader of Badland, wants to invade Fatland. To do this, he needs to calculate how many distinct empires still remain in Fatland after all the takeovers. Help him with this task.

Example:

Input:  n = 4, k = 2, edges = {{1,2},{4,1}}
Output: 2

Approach

C++

#include <bits/stdc++.h>
using namespace std;
void initialize(int arr[], int n)
{
    for (int i = 1i <= ni++)
        arr[i] = i;
}
bool find(int arr[], int aint b)
{
    if (arr[a] == arr[b])
        return true;
    return false;
}
void unionDs(int arr[], int aint bint n)
{
    int temp = arr[a];
    for (int i = 1i <= ni++)
        if (arr[i] == temp)
            arr[i] = arr[b];
}

int cityAndFlood(int nint kvector<vector<int>> &edges)
{
    int arr[n + 1];

    initialize(arrn);
    for (int i = 0i < ki++)
    {
        int a = edges[i][0]b = edges[i][1];
        if (find(arrab) == false)
            unionDs(arrabn);
    }
    map<intintmp;
    for (int i = 1i <= ni++)
        mp[arr[i]]++;
    return mp.size();
}
int main()
{
    int n = 4k = 2;

    vector<vector<int>> edges = {{12}, {41}};

    cout << cityAndFlood(nkedges<< "\n";

    return 0;
}


No comments:

Post a Comment