望空破茧


私信TA

用户名:2075783911

访问量:845

签 名:

我是一位观察者,我是一位被观察者

等  级
排  名 14650
经  验 872
参赛次数 1
文章发表 8
年  龄 19
在职情况 学生
学  校 麻省理工大学
专  业

  自我简介:

解题思路:常规:赋值——比较——得出最小绝对值的下标——调换——输出

注意事项:见代码解析

参考代码:

#include <stdio.h>//输入数据并交换后输出 

#include <math.h> 

int main() 

{

int i,min,s=0,number[9];                       //定义了循环变量i,中间变量 min,下标s,数组number[9] 

for (i=0;i<10;i++)                                 //接收10个数据并储存到数组number中去 

{

scanf("%d",&number[i]);

}

min=number[0];                                 // 赋予中间变量min初始值 

for (i=0;i<9;i++)                                 //进行循环比较得出最小绝对值min,和对应的下标s 

{                                                         //注意点,需在定义处赋初始值s=0;由于存在number[0]为最小绝对值,从而跳出if循环,

                                                          //导致 number[s]=number[9]中s为未知报错,因此需赋初始值 

if(fabs(number[i+1])<fabs(min))

{

min=number[i+1];

s=i+1;

}

}

number[s]=number[9];                   //数值调换 

number[9]=min;                             //注意点,number[s]=number[9];number[9]=min;前后顺序不可搞反 

for (i=0;i<10;i++)                           //循环输出数组number 

printf("%d ",number[i]);

 } 


 

0.0分

2 人评分

  评论区

这个代码是不是错了?

输入:

11
1
45
676
87
567
989
56
23
546

运行的结果是:

11 1 45 676 87 567 989 56 23 1
--------------------------------
Process exited after 21.77 seconds with return value 0
请按任意键继续. . .


1没有与546交换,而且546被1替换
2022-11-05 10:36:52
  • «
  • 1
  • »