USACO1.5 Prime Palindromes(pprime)

        题目中提示的很清楚,先求出回文数,然后检测该数是不是质数。具体实现如下:先求出a,b的位数wa,wb,再求出位数在[wa,wb]之间的所有回文质数存入set中并进行自动排序,其中可能有一些不在范围[a,b]中的数,只需打印出在[a,b]范围内的即可。

 

/*
ID:jzzlee1
PROG:pprime
LANG:C++
*/
#include<iostream>
#include<fstream>
#include<cstring>
#include<set>
#include<cmath>
using namespace std;
ifstream fin("pprime.in");
ofstream fout("pprime.out");
bool check(int p)		//检测是否质数
{
	for(int i=2;i<=(int)sqrtf(p);i++)
		if(p%i==0)
			return 0;
	return 1;
}
int main()
{
	int a,b;
	//cin>>a>>b;
	fin>>a>>b;
	int wa=0,wb=0;
	int x=a,y=b;
	while(x)            //求a的位数wa
	{
		x/=10;
		wa++;
	}
	while(y)            //求b的位数wb
	{
		y/=10;
		wb++;
	}
	set<int> set1;
	int pal;int d1,d2,d3,d4;
	if(wa<3&&wb>0)					// 一位数、两位数
	{
		for(d1=1;d1<=9;d1+=2) 	
		{
			if(wa<2)				//一位数
			{
				pal=d1;
				if(check(pal))
					set1.insert(pal);
			}
			if(wb>1)				//两位数
			{
				pal=11*d1;
				if(check(pal))
					set1.insert(pal);
			}
		}
	}
	if(wa<5&&wb>2)					//三位数、四位数
	{
		for (d1 = 1; d1 <= 9; d1+=2) 
			for (d2 = 0; d2 <= 9; d2++) 
			{
				if(wa<4)			//三位数
				pal=101*d1+10*d2;
				if(check(pal))
					set1.insert(pal);
				if(wb>3)			//四位数
				{
					pal=1001*d1+110*d2;
					if(check(pal))
						set1.insert(pal);
				}
			}
	}
	if(wa<7&&wb>4)					//五位数、六位数
	{
		for (d1 = 1; d1 <= 9; d1+=2) 
			for (d2 = 0; d2 <= 9; d2++) 
				for (d3 = 0; d3 <= 9; d3++) 
				{
					if(wa<6)		//五位数
					{
						pal=10001*d1+1010*d2+100*d3;
						if(check(pal))
							set1.insert(pal);
					}
					if(wb>5)		//六位数
					{
						pal=100001*d1+10010*d2+1100*d3;
						if(check(pal))
							set1.insert(pal);
					}
			}
		}
	if(wa<=9&&wb>6)					//七位数、八位数
	{
		for (d1 = 1; d1 <= 9; d1+=2) 
			for (d2 = 0; d2 <= 9; d2++) 
				for (d3=0;d3<=9;d3++) 
					for(d4=0;d4<=9;d4++)
					{
						if(wa<8)	//七位数
						{
							pal=1000001*d1+100010*d2+10100*d3+1000*d4;
							if(check(pal))
								set1.insert(pal);
						}
						if(wb>7)	//八位数
						{
							pal=10000001*d1+1000010*d2+100100*d3*11000*d4;
							if(check(pal))
								set1.insert(pal);
						}
				}
	}
	set<int>::iterator iter;
	for(iter=set1.begin();iter!=set1.end();iter++)//打印在[a,b]范围内的数
		if(*iter>=a&&*iter<=b)
			//cout<<*iter<<endl;
			fout<<*iter<<endl;
	return 0;
}

你可能感兴趣的:(USACO)