Minimum Distances

The distance between two array values is the number of indices between them. Given a, find the minimum distance between any pair of equal elements in the array. If no such value exists, return  -1.

Example:

Input:  n=6, arr[]={7,1,3,4,1,7}
Output: 3

Approach

C++

#include <bits/stdc++.h>
using namespace std;

//comparator used for sorting
bool cmp(pair<intintapair<intintb)
{
    if (a.first == b.first)
        return a.second < b.second;
    return a.first < b.first;
}
int main()
{
    int n = 6;
    int arr[n] = {713417};

    vector<pair<intint>> v;
    for (int i = 0; i < n; i++)
        v.push_back({arr[i], i});
    sort(v.begin(), v.end(), cmp);
    int i = 1;
    int ans = INT_MAX;

    while (i < n)
    {
        while (i < n && v[i].first == v[i - 1].first)
        {
            ans = min(ans, v[i].second - v[i - 1].second);
            i++;
        }
        i++;
    }
    if (ans == INT_MAX)
        cout << -1 << "\n";
    else
        cout << ans << "\n";
    return 0;
}


No comments:

Post a Comment