博客
关于我
杭电oj 2020 绝对值排序 (Java)(注意换行符在oj上的特别要求)
阅读量:377 次
发布时间:2019-03-05

本文共 1045 字,大约阅读时间需要 3 分钟。

为了解决这个问题,我们需要对给定的整数按照绝对值从大到小进行排序。每个测试实例的输入包括一个整数n,接着是n个整数。当n为0时,输入结束。

方法思路

  • 读取输入:使用Scanner读取输入数据。每行的第一个数字是n,接着是n个整数。当n为0时,输入结束。
  • 排序:对每组数据进行排序,按照绝对值从大到小的顺序排列。可以使用Java的Arrays.sort()方法,并提供一个自定义的比较器来比较两个数的绝对值。
  • 输出结果:输出排序后的结果,每个数之间用空格隔开,每行一组。
  • 解决代码

    import java.util.Scanner;import java.util.Arrays;public class Main {    public static void main(String[] args) {        Scanner input = new Scanner(System.in);        int n;        while (true) {            n = input.nextInt();            if (n == 0) break;            int[] arr = new int[n];            for (int i = 0; i < n; i++) {                arr[i] = input.nextInt();            }            Arrays.sort(arr, (a, b) -> Integer.compare(Math.abs(b), Math.abs(a)));            for (int num : arr) {                System.out.print(num + " ");            }            System.out.println();        }    }}

    代码解释

  • 读取输入:使用Scanner读取输入数据。循环读取每行的数据,直到n为0时结束输入。
  • 存储输入数据:将读取的整数存储到数组arr中。
  • 排序:使用Arrays.sort()方法对数组进行排序,自定义比较器确保按绝对值从大到小排序。
  • 输出结果:遍历排序后的数组,将每个数打印出来,元素之间用空格隔开,每行输出一组数据。
  • 这种方法确保了我们能够高效地读取输入、排序和输出结果,满足题目要求。

    转载地址:http://crpg.baihongyu.com/

    你可能感兴趣的文章
    OSG:从源码看Viewer::run() 一
    查看>>
    OSI七层模型与TCP/IP四层与五层模型详解
    查看>>
    OSI七层模型的TCP/IP模型都有哪几层和他们的对应关系?
    查看>>
    OSM数据如何下载使用(地图数据篇.11)
    查看>>
    OSPF 四种设备角色:IR、ABR、BR、ASBR
    查看>>
    OSPF 学习
    查看>>
    OSPF 概念型问题
    查看>>
    OSPF 的主要目的是什么?
    查看>>
    SQL Server 存储过程分页。
    查看>>
    OSPF不能发现其他区域路由时,该怎么办?
    查看>>
    OSPF两个版本:OSPFv3与OSPFv2到底有啥区别?
    查看>>
    SQL Server 存储过程
    查看>>
    OSPF在大型网络中的应用:高效路由与可扩展性
    查看>>
    OSPF太难了,这份OSPF综合实验请每位网络工程师查收,周末弯道超车!
    查看>>
    OSPF技术入门(第三十四课)
    查看>>
    OSPF技术连载10:OSPF 缺省路由
    查看>>
    OSPF技术连载11:OSPF 8种 LSA 类型,6000字总结!
    查看>>
    OSPF技术连载13:OSPF Hello 间隔和 Dead 间隔
    查看>>
    OSPF技术连载14:OSPF路由器唯一标识符——Router ID
    查看>>
    OSPF技术连载15:OSPF 数据包的类型、格式和邻居发现的过程
    查看>>