【发布时间】:2021-03-31 15:25:36
【问题描述】:
我有下一个任务:
使用块 lambda 表达式编写一个返回屏幕读取数字的类型的供应商
编写一个谓词,告诉我们输入的数字是否是质数,并带有一个带有 for 循环的块表达式。将其应用于供应商的结果。
必须返回:
每个屏幕写入一个整数 24 供应商 24 生成的数字不是素数
或
每个屏幕写一个整数 23 由supplierScreen 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 循环对我来说效果不佳,因为它总是返回它不是素数
-
它还返回布道的“真”,它不应该返回任何东西。
我很感激能得到任何帮助。
【问题讨论】:
标签: java primes predicate supplier