VivianLu


私信TA

用户名:ytl08327

访问量:5858

签 名:

当善良的人摘下面具,你连跪的机会都没有。

等  级
排  名 5734
经  验 1440
参赛次数 1
文章发表 7
年  龄 20
在职情况 学生
学  校 山东政法学院
专  业 信息管理与信息系统

  自我简介:

现就读于山东政法学院信息管理与信息系统专业

解题思路:

注意点:1、绝对值函数abs();

2、排序(可选择冒泡排序、快速排序、归并排序等方法)。

这道题唯一的一个小难点是,输入的值要按照其绝对值的大小进行降序排列,并不是对其绝对值进行排列,因此我们只要在排序判断时对这些数的绝对值大小进行判断就可以了,交换数值顺序还是按照其原值来进行,这样,输出的结果就会带上其原本的符号。

注意事项:

参考代码:

#include<iostream>
#include<math.h>
using namespace std;
int main(){
 int n;
 
 while(cin >> n && n!= 0){
  int a[n];
  for(int i = 0;i < n;i++){
   cin >> a[i];
  }
  
  for(int i = 0;i < n - 1;i++){
   for(int j = 0;j < n - 1 - i;j++){
    if(abs(a[j]) < abs(a[j + 1])){
     swap(a[j],a[j + 1]);
    }
   }
  }
  
  for(int i = 0;i < n;i++){
   cout << a[i] << " ";
  }
 }
 
 return 0;
}


 

0.0分

32 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区

while(cin >> n && n!= 0){
  int a[n];
数组能用变量定义?

我和你类似的方法答案错了50%诶
2019-12-10 08:50:13
  • «
  • 1
  • »