查找一维整型数组A[n]中最小的两个值希望能给出给出设计思想
2条回答 默认 最新
- 快乐鹦鹉 2022-09-07 16:36关注
定义两个整数,分别记录最小值和次小值,并都等于第一个元素。
然后从第二个元素开始判断,如果小于最小值,那么次小值等于当前最小值,当前最小值等于新的元素值;否则,如果小于次小值,那么只需要将次小值改为新的元素值#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); }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用