我是 Java 的新手,所以请原谅我对其中的某些内容是个白痴。我应该编写一个静态方法 isStrictlyIncreasing(double[] in)
如果给定数组中的每个值都大于它之前的值,则返回 true,否则返回 false。另外,我不能使用 java.util.ArrayList
。
这是我的代码:
public static void main(String[] args) {
double in[] = new double[]{45, 15, 25, 79, 89, 45, 66, 33, 56, 105};
Sort(in);
System.out.println("Answer: " + Sort(in));
}
private static boolean Sort(double[] in) {
int n = in.length;
int temp = 0;
for(int i = 0; i < n; i++){
for(int j = 1; j < (n-i); j++){
if(in[j - 1] < in[j]){
return true;
}
return false;
}
}
不幸的是,我一直得到一个列表,其中包含“真、真、真……答案:假”
我知道我的方法有问题,可能是在 if 语句中,我想知道是否有人可以帮助我。
最佳答案
首先,在 Java 中,驼峰式方法名称是常见的做法。也就是说,
private static boolean Sort(double[] in) {
应该变成
private static boolean sort(double[] in) {
其次,return 语句用于从方法返回,因此您可能不想在每次检查后都返回。相反,你会想做这样的事情,
private static boolean Sort(double[] in) {
int n = in.length;
int temp = 0;
for (int i = 0; i < n; i++) {
for (int j = 1; j < (n - i); j++) {
if (in[j - 1] > in[j]) {
return false;
}
}
}
return true;
}
如果序列中的下一个数字不大于它之前的值,则返回 false。然后如果它在没有被触发的情况下通过 for 循环,那么我们知道它们必须按升序排列,因此返回 true
关于java - 我的方法有什么问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33487611/