java - 对三个整数进行排序

标签 java arrays sorting

首先,是的,我正在做一个编程作业的介绍,但是我花了一整天的时间试图解决这个问题,取得了一些进展,但没有成功。

练习是创建一个方法,对 3 个整数从小到大进行排序。我们不鼓励使用数组,但目前我不知道如何在没有数组的帮助下实现这一目标。

我一开始只是想弄清楚如何“排序”3个整数,这就是我想到的:

public class SortInteger {
public static void main(String[]args) {
    int a          = Integer.parseInt(args[0]);
    int b          = Integer.parseInt(args[1]);
    int c          = Integer.parseInt(args[2]);
    int n1, n2, n3 = 0; 


    if      (a < b && a < c) { n1 = a; }
    else if (b < a && b < c) { n1 = b; }
    else    { n1 = c; }

    if      (a > b && a > c) { n3 = a; }
    else if (b > a && b > c) { n3 = b; }
    else    { n3 = c; }

    if      (n1 < a && a < n3) { n2 = a; }
    else if (n1 < b && b < n3) { n2 = b; }
    else    {n2 = c;}

    System.out.println( n1 + " " + n2 + " " + n3);
   }
}

我觉得我可以轻松地减少 if 语句的数量并简化上面代码中的很多行,但是我想等到我成功后再开始清理程序。另外,该代码可以工作,但目标是将其编写为静态方法。因此,在走到这一步之后,我开始尝试将其转换为静态方法,并且已经走到了这一步:

public class SortInteger2 {
public static int sort(int a, int b, int c) { 
    int []s = new int [3];

    if      (a < b && a < c) { s[0] = a; }
    else if (b < a && b < c) { s[0] = b; }
    else    {s[0] = c;}

    if      (a > b && a > c) { s[2] = a; }
    else if (b > a && b > c) { s[2] = b; }
    else    {s[2] = c;}

    if      (s[0] < a && a < s[2]) { s[1] = a; }
    else if (s[0] < b && b < s[2]) { s[1] = b; }
    else    {s[1] = c;}

    return s[]; //I dont know how to return an array, this didnt work for me
 }

public static void main(String[]args) {
    int A   = Integer.parseInt(args[0]);
    int B   = Integer.parseInt(args[1]);
    int C   = Integer.parseInt(args[2]);

    int []S = new int [3];
     S = sort(A,B,C);
    System.out.println(S[0] + " " + S[1] + " " + S[2]); 
 }
}

我知道我只能返回一个对象,这就是为什么我选择使用数组来存储三个整数,然后简单地返回作为数组的单个对象。然而,当我尝试时,编译器仍然对我大喊大叫。我在这里缺少什么?我觉得它是如此明显,但当我一遍又一遍地检查它时,有些东西没有点击。如果我能被引导到正确的方向,我将非常感激!

最佳答案

“我觉得我可以轻松减少 if 语句的数量并简化上面代码中的很多行,”

您可以继续使用 a、b、c 而不是创建新变量,并根据它们的比较来交换它们,但除此之外,没有太多需要进行的减少。

“此外,该代码可以工作,但目标是将其编写为静态方法。”

为什么不这样做呢?

public static void sort(int a, int b, int c) {
    ...

    System.out.println( n1 + " " + n2 + " " + n3);
   }

public static void main(String[] args) {
    sort(2, 5, 9);
}

如果您仍打算使用数组,请将 sort 的返回值更改为 int[]。然后,将 return s[] 行更改为 return s,表示您要返回数组。

关于java - 对三个整数进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26446465/

相关文章:

java - 基于服务器的 SwingWorker 不会停止

php - 使用 PHP 从类似于 SQL LIKE '%search%' 的数组中过滤值

java - 将文件读取到字符串数组并显示每条记录

c - 通用排序适用于整数但不适用于其他类型

java - 按大文件 ArrayList 的日期快速排序

java - 如何在 Java 中比较两个数字?

Java Nio 绝对路径转相对路径

java - 选择列并从其他选择中隐藏

javascript - 在检查 javascript 数组中的重复值并忽略其中一些重复值时,我的代码出现问题

c# - 从另一个数组顺序排序一个数组?