HDOJ 2012 素数判定

2021-01-20 15:56:51 浏览数 (1)

Problem Description 对于表达式n^2 n 41,当n在(x,y)范围内取整数值时(包括x,y)(-39<=x < y<=50),判定该表达式的值是否都为素数。

Input 输入数据有多组,每组占一行,由两个整数x,y组成,当x=0,y=0时,表示输入结束,该行不做处理。

Output 对于每个给定范围内的取值,如果表达式的值都为素数,则输出”OK”,否则请输出“Sorry”,每组输出占一行。

Sample Input 0 1 0 0

Sample Output OK

代码语言:javascript复制
import java.util.Scanner;
class Main{
  public static void main(String args[]){
      Scanner sc = new Scanner(System.in);
      while(sc.hasNext()){
         int x = sc.nextInt();
         int y = sc.nextInt();
         if(x==0&&y==0)
         return ;
         int flag = 0;
         for(int i=x;i<=y;i  ){
             if(!susu(i*i i 41)){
                 System.out.println("Sorry");
                 flag=1;
                 break;
             }
         }
         if(flag==0)
         System.out.println("OK");
      }
  }
  public static boolean susu(int n ){
  //判断n是否是素数,是素数返回true
      for(int i=2;i*i<=n;i  ){
          if(n%i==0)
          return false;
      }
      return true;
  }
}

0 人点赞