未排列的n个数组元素的最大间距

#include <iostream>
using namespace std;

template<class T>
int maxi(int n, T a[])
{
    int k = 1;
    for(int i=2; i <=n; i++)
    {
        if(a[i]>a[k])
        {
            k = i;
        }
    }
    return k;
}

template<class T>
int mini(int n, T a[])
{
    int k = 1;
    for(int i=2; i <=n; i++)
    {
        if(a[i]<a[k])
        {
            k = i;
        }
    }
    return k;
}

double maxgap(int n, double a[])
{
    double mina = a[mini(n, a)], maxa = a[maxi(n, a)];
    int *count = new int[n+1];
    double *low = new double[n+1];
    double *high = new double[n+1];

    int i;
    for(i=1; i<=n; i++)
    {
        count[i] = 0;
        low[i] = maxa;
        high[i] = mina;
    }

    for(i=1; i<=n; i++)
    {
        int bucket = (int)(a[i]-mina)/(maxa-mina)*(n-1)+1;
        cout << i << "  " << bucket <<endl;
        count[bucket]++;
        if(low[bucket] > a[i]) low[bucket] = a[i];
        if(high[bucket] < a[i]) high[bucket] = a[i];
    }

    for(i=1; i<=n; i++)
    {
        cout << low[i] << "  " << high[i] << endl;
    }

    double temp = 0, left = high[1];
    for(i=2; i<n; i++)
    {
        if(count[i])
        {
            double gap = low[i] - left;
            if(gap>temp) temp = gap;
            left = high[i];
        }
    }
    cout << temp << endl;
    delete [] count;
    delete [] low;
    delete [] high;
    return temp;
}


int _tmain(int argc, _TCHAR* argv[])
{
    int n;
    cin >> n;
    double *a = new double[n+1];
    for(int i=1; i<=n; i++)
        cin >> a[i];
    cout << maxgap(n, a) << endl;
    delete [] a;
    system("pause");
    return 0;
}
/*5 2.3 3.1 7.5 1.5 6.3
1  1
2  1
3  5
4  1
5  3
1.5  3.1
7.5  1.5
6.3  6.3
7.5  1.5
7.5  7.5
3.2
3.2*/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值