1

与蛮力 θ(n2) 相比,对数组进行预排序,使算法 θ(nlogn) [排序+查找最小距离]。两个代码都执行相同的工作,但第一个代码显示超出时间限制。我想知道错误是什么。代码中的任何错误?

带有while循环的代码(超出时间限制)


#include <stdio.h>

void mindistance(int a[],int n)
{
    int i=1,arraymin=999,currentmin,current=a[0];

    while(i<n)
    {
        if(a[i]==current)
            i++;
        else
        {
            currentmin=a[i]-a[i-1];
            if(currentmin<arraymin)
            {
                arraymin=currentmin;
                current=a[i];
                i++;
            }

        }
    }
    printf("%d",arraymin);
}


int main(void)
{

    int a[]={4,34,56,77,99,424,754}; 
    mindistance(a,7);

    return 0;
}

使用 for 循环的代码(效果很好)


#include <stdio.h>

void mindistance(int a[],int n)
{
    int i,arraymin=999,currentmin,current=a[0],x,y;

    for(i=1;i<n;i++)
    {
        if(a[i]==current)
            continue;
        else
        {
            currentmin=a[i]-a[i-1];
            if(currentmin<arraymin)
            {
                arraymin=currentmin;
                current=a[i];

            }

        }
    }
    printf("%d",arraymin);
}


int main(void)
{

    int a[]={4,34,56,77,99,424,754};
    mindistance(a,7);

    return 0;
}
4

2 回答 2

1

循环不相同。在 for 循环中 i 在每次迭代中都会增加,而在 while 循环中 i 仅在某些情况下增加。一个相同的 while 循环将是:

while(i<n)
{
    if(a[i]==current)
        i++;
    else
    {
        currentmin=a[i]-a[i-1];
        if(currentmin<arraymin)
        {
            arraymin=currentmin;
            current=a[i];
        }
        i++;
    }
}
于 2016-03-26T19:47:20.580 回答
0

我相信您会陷入无限循环,因为您没有在每次迭代时都设置电流值。

于 2016-03-23T17:27:16.940 回答