使用多个类时一次输入全部时出错,并且在单个类中可以正常工作

时间:2019-01-13 09:11:57

标签: java class inheritance java.util.scanner

如果我只使用一个类,它会完美工作,但是当我使用多个类时,我会遇到一个问题,当我将输入全部作为批处理(复制粘贴)提供时,它不起作用(仍在等待以获得更多输入,但什么也不做),但是当我手动输入每个输入时,效果很好。

所以,这个问题是在我引入一个新类时开始的,所以我猜想在与Scanner类一起使用时,该类或继承有问题。

注意:这是为我的大学实验室准备的,所以我不能在这里使用文件。

codeWithSingleClass-完美的作品

import java.io.*;
import java.lang.*;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        int nooftestCases=scanner.nextInt();

        while(nooftestCases>0) {
            int n,k;
            int[] array = new int[20];
            int sumWithOutRemoval=0 , sumWithRemoval=0;
            n = scanner.nextInt();
            k = scanner.nextInt();
            sumWithOutRemoval = 0;
            for (int i = 0; i < n; i++) {
                array[i] = scanner.nextInt();
                sumWithOutRemoval += array[i];
            }
            if (k == 0) {
                double finalAns = (double) sumWithOutRemoval / n;
                System.out.println(String.format("%.6f", finalAns));
            } else {
                for (int i = 0; i < n; i++) {
                    for (int j = i; j < n; j++) {
                        if (array[i] < array[j]) {
                            int temp = array[i];
                            array[i] = array[j];
                            array[j] = temp;
                        }
                    }
                }
                sumWithRemoval = 0;
                for (int i = 1; i < n - 1; i++) {
                    sumWithRemoval += array[i];
                }
                double finalAns = (double) (sumWithRemoval / (n - (2 * k)));
                System.out.println(String.format("%.6f", finalAns));
            }
            nooftestCases--;
        }
    }
}

codeWithMultipleClasses-hasIssues

import java.io.*;
import java.lang.*;
import java.util.Scanner;

class Sample {

    static int n,k;
    static int[] array = new int[20];
    static int sumWithOutRemoval , sumWithRemoval;

    public void getDetails(){
        Scanner scanner2=new Scanner(System.in);
        n = scanner2.nextInt();
        k = scanner2.nextInt();
        sumWithOutRemoval = 0;
        for (int i = 0; i < n; i++) {
            array[i] = scanner2.nextInt();
            sumWithOutRemoval += array[i];
        }
    }
    public void displayDetails(){
        if (k == 0) {
            double finalAns = (double) sumWithOutRemoval / n;
            System.out.println(String.format("%.6f", finalAns));
        }
        else {
            for (int i = 0; i < n; i++) {
                for (int j = i; j < n; j++) {
                    if (array[i] < array[j]) {
                        int temp = array[i];
                        array[i] = array[j];
                        array[j] = temp;
                    }
                }
            }
            sumWithRemoval = 0;
            for (int i = 1; i < n - 1; i++) {
                sumWithRemoval += array[i];
            }
            double finalAns = (double) (sumWithRemoval / (n - (2 * k)));
            System.out.println(String.format("%.6f", finalAns));
        }
    }
}
public class Main extends Sample {
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        int nooftestCases=scanner.nextInt();
        Sample objname= new Sample();
        while(nooftestCases>0) {
            objname.getDetails();
            objname.displayDetails();
            nooftestCases--;
        }
    }
}

我的输入是

5
5 0
2 9 -10 25 1
5 1
2 9 -10 25 1
5 1
2 9 -10 25 1
5 0
2 9 -10 25 1
5 1
2 9 -10 25 1

预期产量

5.400000
4.000000
4.000000
5.400000
4.000000

1 个答案:

答案 0 :(得分:1)

您的代码有两个Scanner实例;他们正在模拟输入蒸汽。如果我们更改代码以将Scanner scanner传递到Sample对象中,并使用它而不是scanner2,那么一切都很好。

即像这样的东西:

Scanner scanner = new Scanner(System.in);
int nooftestCases = scanner.nextInt();
Sample objname = new Sample(scanner);

并且:

class Sample {
    ...

    private final Scanner scanner;

    public Sample(Scanner scanner) {
        this.scanner = scanner;
    }

    public void getDetails() {
        n = scanner.nextInt();
        k = scanner.nextInt();
        sumWithOutRemoval = 0;
        for (int i = 0; i < n; i++) {
            array[i] = scanner.nextInt();
            sumWithOutRemoval += array[i];
        }
    }
...

顺便说一句,此代码还有很多改进的机会。格式化将是其中之一,尤其是在Stack Overflow上发布时。 static字段是其他令我特别困扰的东西(更不用说它们未指定的范围了)。对于使这样的算法代码在更广泛的应用程序中很好地工作,这将令人怀疑。 kv是什么(建议使用更具描述性的名称)。