思路:1、a、b、c是三个94以内的质数;
2、三个质数要满足图中条件;
3、只需计算出94以内的素数,依次遍历满足两个等式的则输出即可。
代码如下:
import java.util.ArrayList;
import java.util.Scanner;
//输入一个数n输出n以内的素数
public class Test {
public static void main(String[] args) {
Scanner scanner=new Scanner(System.in);
while (scanner.hasNext()) {
int n = scanner.nextInt();
Test.sushu(n);
}
scanner.close();
}
public static void sushu(int n){
ArrayList<Integer> a=new ArrayList<Integer>();
// int count=0;
for (int i = 1; i <n ; i++) {
boolean flag=true;//是否是素数的标志
for (int j = 2; j <=Math.sqrt(i) ; j++) {//除了1和本身外如果还能被除就说明不是素数
if (i%j==0){
flag=false;//不是素数
}
}
if(flag){
//count++;//统计素数个数
// System.out.println("第"+count+"个素数"+i);
a.add(i);//将n以内的素数存储到数组a中
}
}
for (int i = 0; i < a.size(); i++) {//遍历a数组选出三个符合条件的数,为避免重复选择j = i+1,b=j+1
for (int j = i+1; j< a.size(); j++) {
for(int b=j+1;b<a.size();b++) {
int x=a.get(i)+a.get(j)+a.get(b);//x存放a+b+c的值
int y=a.get(i)*a.get(j)+a.get(i)*a.get(b)+a.get(b)*a.get(j);//y存放ab+bc+ac的值
if(x==94&&y==2075) {
System.out.println(a.get(i) + " "+a.get(j)+ " "+a.get(b));
}
}
}
}
}
}
结果如下:
三个数分别是:2,31,61
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/80394.html