查找一维整型数组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无用
悬赏问题
- ¥15 Stata链式中介效应代码修改
- ¥15 latex投稿显示click download
- ¥15 请问读取环境变量文件失败是什么原因?
- ¥15 在若依框架下实现人脸识别
- ¥15 添加组件无法加载页面,某块加载卡住
- ¥15 网络科学导论,网络控制
- ¥100 安卓tv程序连接SQLSERVER2008问题
- ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
- ¥15 metadata提取的PDF元数据,如何转换为一个Excel
- ¥15 关于arduino编程toCharArray()函数的使用