我有下一个任务:
编写一个类型的供应商,该类型返回一个由屏幕读取的数字,带有一个块 lambda 表达式
编写一个谓词,告诉我们输入的数字是否是素数,并带有一个带有 for 循环的块表达式。将其应用于供应商的结果。
必须返回:
每个屏幕写一个整数 24 供应商生成的数字 24 不是素数
或者
每个屏幕写入一个整数 23 供应商屏幕生成的数字 23 是 primo
取决于输入的数字是否为素数。
我制作的代码如下:
import java.util.Scanner;
import java.util.function.Supplier;
import java.util.function.Predicate;
public class Ejercicio4 {
public static void main(String[] args) {
Scanner teclado = new Scanner(System.in);
Supplier <Integer> numeroPorPantalla = () ->{
int n;
System.out.println("Escriba un número entero por pantalla");
n=teclado.nextInt();
return n;
};
Predicate<Integer> esPrimo = (n) -> {
int a = 0;
int i;
for (i=1; i<= n; i++) {
if (n % 1 == 0) {
a++;
}
}
if (a != 2) {
System.out.println("The supplier number "+numeroPorPantalla.get()+" is not prime");
} else {
System.out.println("The supplier number "+numeroPorPantalla.get()+" is prime");
}
return true ;
};
System.out.println("");
System.out.print(esPrimo.test(numeroPorPantalla.get()));
}
}
我在跑步时遇到的问题是:
它要求我输入 2 倍的值,而它应该只有 1 倍。
FOR 循环对我来说效果不佳,因为它总是返回它不是素数
它还返回布道的“真实”,它不应该返回任何东西。
我很感激我能得到的任何帮助。