Legjobb válasz
A Java-ban az Class Scanner használatával beolvashatja az input-ot, a System.out pedig a kimenet kinyomtatásához.
Scanner scanner = new Scanner(System.in);
int n = scanner.nextInt(); // read an integer from input stream.
System.out.println(n) // print n
Azonban időnként túllépi az időhatárt (TLE) a Scanner teljesítménye miatt. Használhatja helyette a BufferedReadert.
class InputReader {
public BufferedReader reader;
public StringTokenizer tokenizer;
public InputReader(InputStream stream) {
reader = new BufferedReader(new InputStreamReader(stream), 32768);
tokenizer = null;
tokenizer = null;
}
public String next() {
while (tokenizer == null || !tokenizer.hasMoreTokens()) {
try {
tokenizer = new StringTokenizer(reader.readLine());
} catch (IOException e) {
throw new RuntimeException(e);
}
}
return tokenizer.nextToken();
}
public int nextInt() {
return Integer.parseInt(next());
}
public long nextLong() {
return Long.parseLong(next());
}
}
Válasz
Engedje meg, hogy megpróbáljam elmagyarázni a Dühös professzor probléma a HackerRank-tól.
A System.in beolvasott és a kimenetet kinyomtató kód követése magától értetődő:
import java.io.*;
import java.util.*;
public class Solution {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int t = in.nextInt();
for (int i = 0; i < t; i++) {
int nstudent = in.nextInt();
int threshold = in.nextInt();
int[] arrival = new int[nstudent];
for (int j = 0; j < nstudent; j++) {
arrival[j] = in.nextInt();
}
algo(arrival, threshold);
}
}
public static void algo(int[] arrival, int threshold){
//your implementation
}
}