0

0

Java 数组排序及表格输出教程

碧海醫心

碧海醫心

发布时间:2025-10-21 13:45:01

|

904人浏览过

|

来源于php中文网

原创

java 数组排序及表格输出教程

本文档旨在指导读者如何对 Java 数组中的元素进行排序,并以表格形式输出排序前后的数据。我们将使用选择排序算法对用户输入的测试分数进行排序,并展示如何保留原始索引信息,最终以清晰的表格形式呈现排序结果。本文档将提供详细的代码示例和步骤说明,帮助读者理解并实现数组排序和格式化输出

理解需求

我们需要对用户输入的测试分数进行排序,并在排序后以表格形式输出。关键在于,需要保留原始输入顺序的索引信息,以便在排序后的表格中正确显示“Grade Number”。这意味着我们不能直接对原始数组进行排序,而需要借助辅助数组来保存索引信息。

解决方案

以下是一种实现该功能的方案:

易通cmseasy免费的企业建站程序2.0 UTF-8 build 201000510 中文版
易通cmseasy免费的企业建站程序2.0 UTF-8 build 201000510 中文版

易通(企业网站管理系统)是一款小巧,高效,人性化的企业建站程序.易通企业网站程序是国内首款免费提供模板的企业网站系统.§ 简约的界面及小巧的体积:后台菜单完全可以修改成自己最需要最高效的形式;大部分操作都集中在下拉列表框中,以节省更多版面来显示更有价值的数据;数据的显示以Javascript数组类型来输出,减少数据的传输量,加快传输速度。 § 灵活的模板标签及模

下载
  1. 创建索引数组: 创建一个与测试分数数组大小相同的索引数组,初始化为 [0, 1, 2, ..., n-1]。
  2. 自定义排序方法: 修改原有的selectionSort方法,使其能够根据测试分数数组的值对索引数组进行排序。
  3. 输出排序后的表格: 遍历排序后的索引数组,并根据索引从测试分数数组中取出对应的值,输出到表格中。

代码实现

import java.util.Scanner;

public class ArrayIntro2 {

    public static void main(String[] args) {
        // integer array
        int[] TestGrades = new int[25];

        // creating object of ArrayIntro2T
        ArrayIntro2T pass = new ArrayIntro2T(TestGrades, 0, 0, 0);

        // getting total and filling array
        int scoreCount = ArrayIntro2T.FillArray(TestGrades, 0);

        // get average score
        double avg = pass.ComputeAverage(TestGrades, scoreCount);

        // outputting unsorted table
        System.out.println("Original Test Scores:");
        ArrayIntro2T.OutputArray(TestGrades, scoreCount, avg);

        // Sort and output sorted table
        System.out.println("\nTable of sorted test scores");
        ArrayIntro2T.OutputSortedArray(TestGrades, scoreCount, avg);

    }

}

// new class to store methods
class ArrayIntro2T {
    // variable declaration

    double CalcAvg = 0;
    int ScoreTotal = 0;
    int ScoreCount = 0;
    int[] TestGrades = new int[25];

    // constructor
    public ArrayIntro2T(int[] TestGradesT, int ScoreCountT, double CalcAvgT, int ScoreTotalT) {
        TestGrades = TestGradesT;
        ScoreCount = ScoreCountT;
        CalcAvg = CalcAvgT;
        ScoreTotal = ScoreTotalT;

    }

    // method to fill array
    public static int FillArray(int[] TestGrades, int ScoreCount) {

        Scanner scan = new Scanner(System.in);

        System.out.println("Please enter test scores one at a time, up to 25 values or enter -1 to quit");
        TestGrades[ScoreCount] = scan.nextInt();

        if (TestGrades[ScoreCount] == -1) {
            System.out.println("You have chosen to quit ");
        }

        while (TestGrades[ScoreCount] >= 0 && ScoreCount < TestGrades.length -1) {
            ScoreCount++;
            System.out.println("Enter the next test score or -1 to finish ");
            TestGrades[ScoreCount] = scan.nextInt();
            if (TestGrades[ScoreCount] == -1) {
                break;
            }
        }
        return ScoreCount;

    }

    // method to compute average
    public double ComputeAverage(int[] TestGrades, int ScoreCount) {

        for (int i = 0; i < ScoreCount; i++) {
            ScoreTotal += TestGrades[i];
            CalcAvg = (double) ScoreTotal / (double) ScoreCount;
        }

        return CalcAvg;

    }

    public static void selectionSort(int[] arr, int[] indices, int length) {
        for (int i = 0; i < length - 1; i++) {
            int minIndex = i;
            for (int j = i + 1; j < length; j++) {
                if (arr[indices[j]] < arr[indices[minIndex]]) {
                    minIndex = j;
                }
            }
            // Swap indices
            int temp = indices[i];
            indices[i] = indices[minIndex];
            indices[minIndex] = temp;
        }
    }

    // method to output scores and average
    public static void OutputArray(int[] TestGrades, int ScoreCount, double CalcAvg) {

        System.out.println("Grade Number\t\tGrade Value");

        for (int i = 0; i < ScoreCount; i++) {
            System.out.println((i + 1) + "\t" + "\t" + "\t" + TestGrades[i]);
        }

        System.out.printf("Calculated Average\t" + "%.2f%%\n", CalcAvg);

    }

    public static void OutputSortedArray(int[] TestGrades, int ScoreCount, double CalcAvg) {
        int[] indices = new int[TestGrades.length];
        for (int i = 0; i < TestGrades.length; i++) {
            indices[i] = i;
        }

        selectionSort(TestGrades, indices, ScoreCount);

        System.out.println("Grade Number\t\tGrade Value");

        for (int i = 0; i < ScoreCount; i++) {
            System.out.println((indices[i] + 1) + "\t" + "\t" + "\t" + TestGrades[indices[i]]);
        }

        System.out.printf("Calculated Average\t" + "%.2f%%\n", CalcAvg);
    }

}

代码解释

  • selectionSort(int[] arr, int[] indices, int length): 这个方法现在接受原始数组 arr,索引数组 indices 和需要排序的数组长度length 作为参数。它根据 arr 中的值对 indices 数组进行排序,使得 indices 数组中的元素按照 arr 中对应位置的值从小到大排列
  • OutputSortedArray(int[] TestGrades, int ScoreCount, double CalcAvg): 这个方法首先创建并初始化索引数组 indices。然后,调用 selectionSort 方法对索引数组进行排序。最后,它遍历排序后的索引数组,并使用索引从 TestGrades 数组中获取相应的值,并以表格形式输出。
  • 在 main 方法中,调用 OutputArray 输出原始数组,调用 OutputSortedArray 输出排序后的数组。

运行结果

程序首先会要求用户输入测试分数,然后输出原始的测试分数表格,接着输出排序后的测试分数表格。排序后的表格会显示按照分数从小到大排列的成绩,并保留原始的“Grade Number”。

立即学习Java免费学习笔记(深入)”;

注意事项

  • 代码中假设用户最多输入 25 个测试分数。可以根据实际需求修改数组的大小。
  • selectionSort 方法是对选择排序算法的实现。您可以根据需要选择其他排序算法。
  • 在实际应用中,可以考虑使用 Java 提供的 Arrays.sort 方法,并结合 Comparator 接口来实现更灵活的排序需求。

总结

通过创建索引数组并对其进行排序,我们可以在对数组元素进行排序的同时,保留原始的索引信息。这种方法在需要维护原始数据顺序的场景下非常有用。本教程提供了一个完整的示例,展示了如何在 Java 中实现数组排序和格式化输出,希望能够帮助读者更好地理解和应用相关技术。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

408

2023.09.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

930

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

602

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

294

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

212

2025.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

294

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

105

2025.10.23

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1800

2023.10.19

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

2

2026.03.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.1万人学习

C# 教程
C# 教程

共94课时 | 10.7万人学习

Java 教程
Java 教程

共578课时 | 77.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号