排序三个整数

时间:2014-10-19 01:48:52

标签: 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]); 
 }
}

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

2 个答案:

答案 0 :(得分: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,表示您正在返回数组。

答案 1 :(得分:0)

你非常接近。

您需要做的就是将sort方法的返回类型从int更改为int[],以表示您正在返回整数数组。然后,在返回行return s[];s[]更改为s。你不需要括号,因为你要返回整个数组。

我跑了这个,它对我有用。