杭电2012-素数判定

#include <cstdlib>
#include <iostream>
#include<cmath>
using namespace std;

//高效判定素数
bool prime(int n)
{
     if(n==2)
        return true;
     if(n%2==0)
        return false;
     int sqrtn=(int)sqrt((double)n);
     bool flag=true;
     for(int i=3;i<=sqrtn;i+=2)
        if(n%i==0)
         flag=false;
     return flag;
}
int main(int argc, char *argv[])
{
    int x,y,count;
    while(cin>>x>>y)
    {
       if(x==0&&y==0)
        break;
        count=0;
        for(int i=x;i<=y;i++)
        {
          if(!prime(i*i+i+41))
           count++;
        }
        if(count==0)
          cout<<"OK"<<endl;
        else
          cout<<"Sorry"<<endl;
    }
    system("PAUSE");
    return EXIT_SUCCESS;
}

posted @ 2015-03-08 22:18  泡面小王子  阅读(137)  评论(0编辑  收藏  举报