c语言 算法 数据结构 思路

查找一维整型数组A[n]中最小的两个值希望能给出给出设计思想

定义两个整数,分别记录最小值和次小值,并都等于第一个元素。
然后从第二个元素开始判断,如果小于最小值,那么次小值等于当前最小值,当前最小值等于新的元素值;否则,如果小于次小值,那么只需要将次小值改为新的元素值

#include <stdio.h>
int main()
{
    int a[1000],n,a1,a2,i;
    scanf("%d",&n);
    for(i=0;i<n;i++)
        scanf("%d",&a[i]);
    a1 = a2 = a[0];
    for(i=1;i<n;i++)
    {
        if(a[i] < a1)
        {
            a2 = a1;
            a1 = a[i];
        }
        else if(a[i] < a2)
            a2 = a[i];
    }
    prinf("最小值:%d,次小值:%d\n",a1,a2);
}

时间复杂度 应该是n-2
直接穷举就好,从 i = 2开始一直到 n,如果小于i=-0,就替换,如果小于i=1 的替换,否则下一个