L1-028 判断素数 PAT团体程序设计天梯赛-练习集 java

题目: L1-028 判断素数 (10 分)

本题的目标很简单,就是判断一个给定的正整数是否素数。

输入格式
输入在第一行给出一个正整数N(≤ 10),随后N行,每行给出一个小于231

​​ 的需要判断的正整数。

输出格式
对每个需要判断的正整数,如果它是素数,则在一行中输出Yes,否则输出No。

输入样例

2
11
111

输出样例

Yes
No

代码如下

import java.util.Scanner;
 
public class L1_028 {
	public static void main(String args[]) {
		Scanner std=new Scanner(System.in);
		int Num=std.nextInt();
		int[] arr=new int[Num];
		for(int i=0;i<Num;i++) {
			arr[i]=std.nextInt();
		}
		for(int i=0;i<Num;i++) {
			if(isprime(arr[i])) {
				System.out.println("Yes");
			}
			else System.out.println("No");
		}
	}	
  
	public static boolean isprime(int n)
   	    {
   	        if(n<2)
   	            return false;
   	        else
   	        {
   	            for(int i=2;i<Math.sqrt(n);i++)
   	            {
   	                if(n%i==0)
   	                    return false;
   	            }
   	        }
   	        return true;
   	    }
	}

:以上代码是借鉴别人的,我之前写的是用数组存储结果yes或no,但是有两个样例运行不通过,猜测是运行超时了,以上代码可以通过全部样例

你可能感兴趣的:(天梯赛,java)