查找一维整型数组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 的替换,否则下一个