解题思路:
先把数组元素全部换算至对应的绝对值放进另一个数组,然后遍历比较换算为绝对值之后的数组,找出最小值的下标,用来方便与最后一个元素进行交换,最后输出原来的数组。到这里相信大家都会做了吧!!
注意事项:
注意题目说的是绝对值
参考代码:
//二级C语言-最小绝对值
#include<stdio.h>
#include<math.h>
int main()
{
int a[10],s[10];
int t;
int temp;
for(int i=0;i<10;i++){
scanf("%d",&s[i]);
a[i]=abs(s[i]);//这里换算绝对值
}
int min=a[0];
for(int i=1;i<=9;i++){
if(min>a[i]){
min=a[i];//这里遍历比较找最小值
t=i;//这里是下标
}
}
temp=s[t];
s[t]=s[9];
s[9]=temp;//这里与最后的元素进行交换
for(int j=0;j<10;j++){
// if(j==9){
// printf("%d",a[9]);
// break;//
// }
printf("%d ",s[j]);//最后输出就可以啦
}
return 0;
}
0.0分
2 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复