1217: VIJOS-P1042

时间限制: 0 Sec  内存限制: 128 MB

提交: 78  解决: 29

[提交][状态][讨论版]

题目描述

        有一天,雄霸传授本人风神腿法第一式:捕风捉影..............的步法(弟子一:堂主,你大喘气呀。风:你给我闭嘴。)捕风捉影的关键是换气(换不好就会大喘气...)。         使用捕风捉影这一招时并不是每一步都喘气,而是在特定的步数喘气。一般来说功力越高,喘气越稀疏。喘气的步数符合特定规律:第一要是SUSHU(弟子二:哇塞!堂主,你还会鸟语,我好好崇拜你呦!可是SUSHU是什么意思呢?风:笨蛋,那是汉语拼音!)第二要是一个回文数,回文数就是正反念一样的数,如:123321,121,5211314(弟子三:堂主,最后一个好象不是...风:废话,当然不是了,我是考察一下你们的纠错能力!)现在给出两个数M,N(5<
=M< N< =100,000,000),你要算出M,N之间需要换气的都有哪几步。(包括M,N)。算出来的可以提升为本堂一级弟子,月薪(1000000000000000000000000000000000000000000  MOD  10  )元。

输入

两个整数M,N。用空格隔开。

输出

在M,N之间的换气点,每个一行。

样例输入

100 500

样例输出

101
131
151
181
191
313
353
373
383

#include<stdio.h>
#include<string.h>
int prime[4000];
int psize;
int from, to;
void getPrime(){
	memset(prime, 0, sizeof(prime));
	psize = 0;
	int i,j;
	bool a[10000];
	memset(a, -1, sizeof(a));
	for (i = 2; i < 10000; i++){
		if (!a[i])continue;
		prime[psize++] = i;
		for (j = i + i; j < 10000; j+=i)a[j] = false;
	}
}
bool isPrime(int n){
	int i;
	for (i = 0;prime[i]*prime[i]<=n; i++)if (n%prime[i] == 0)return false;
	return true;
}
void one(){
	if (from>7)return;
	if (from == 5)printf("5\n");
	printf("7\n");
}
void three(){
	if (from > 999)return;
	int i, j,k;
	int a[4] = { 1, 3, 7, 9 };
	for (i = 0; i < 4;i++)
	for (j = 0; j < 10; j++){
		k = a[i] * 100 + j * 10 + a[i];
		if ( k< from)continue;
		if (k>to)return;
		if (isPrime(k))printf("%d%d%d\n", a[i], j,a[ i]);
	}
}
void five(){
	if (from>99999)return;
	int a[4] = { 1, 3, 7, 9 };
	int i, j, k, l;
	for (i = 0; i < 4;i++)
	for (j = 0; j < 10;j++)
	for (k = 0; k < 10; k++){
		l = a[i] * 10000 + j * 1000 + k * 100 + j * 10 + a[i];
		if (l<from)continue;
		if (l>to)return;
		if (isPrime(l))printf("%d%d%d%d%d\n", a[i], j, k, j, a[i] );
	}
}
void seven(){
	if (from>9999999)return;
	int a[4] = { 1, 3, 7, 9 };
	int i, j, k, l,m;
	for (i = 0; i < 4; i++)
	for (j = 0; j < 10; j++)
	for (k = 0; k < 10; k++)
	for(m=0;m<10;m++){
		l = a[i] * 1000000 + j * 100000 + k * 10000 + m * 1000 +k*100+j*10+ a[i];
		if (l<from)continue;
		if (l>to)return;
		if (isPrime(l))printf("%d%d%d%d%d%d%d\n", a[i], j, k,m,k, j, a[i]);
	}
}
int main(){
	getPrime();
	prime[psize++]=10001;
	scanf("%d%d", &from, &to);
	one();
	if (11 >= from && 11 <= to)printf("11\n");
	three(); five(); seven();
	return 0;
}


上面这个5ms

再慢一点的算法:6311ms

#include<stdio.h>
#include<string.h>
#include<math.h>
int prime[4000];
int psize;
int from, to;
void getPrime(){
	memset(prime, 0, sizeof(prime));
	psize = 0;
	int i,j;
	bool a[10000];
	memset(a, -1, sizeof(a));
	for (i = 2; i < 10000; i++){
		if (!a[i])continue;
		prime[psize++] = i;
		for (j = i + i; j < 10000; j+=i)a[j] = false;
	}
}
bool isPrime(int n){
	int i;
	for (i = 0;prime[i]*prime[i]<=n; i++)if (n%prime[i] == 0)return false;
	return true;
}
bool isHuiwen(int n,int wei){
	if (wei == 0||wei==1)return true;
	int i;
	if (n /(int) pow((double)10, wei-1) == n % 10){
		n %= (int)pow((double)10, wei-1);
		n /= 10;
		if (isHuiwen(n, wei - 2))return true;
	}
	return false;
}
int main(){
	getPrime();
	prime[psize++]=10001;
	scanf("%d%d", &from, &to);
	if (from == 5)printf("5\n");
	if (from <= 7 && to >= 7)printf("7\n");
	if (11 >= from && 11 <= to)printf("11\n");
	if (from < 100)from = 101;
	for (; from <= to; from++){
		int wei = log10((double)from)+1;
		if (wei % 2 == 0){
			from = pow((double)10, wei);
			wei++;
			if (from>to)break;
		}
		if (isPrime(from) && isHuiwen(from,wei))
			printf("%d\n", from);
	}
	return 0;
}

最慢42805ms

#include<stdio.h>
#include<string.h>
#include<math.h>
int prime[4000];
int psize;
int from, to;
void getPrime(){
	memset(prime, 0, sizeof(prime));
	psize = 0;
	int i,j;
	bool a[10000];
	memset(a, -1, sizeof(a));
	for (i = 2; i < 10000; i++){
		if (!a[i])continue;
		prime[psize++] = i;
		for (j = i + i; j < 10000; j+=i)a[j] = false;
	}
}
bool isPrime(int n){
	int i;
	for (i = 0;prime[i]*prime[i]<=n; i++)if (n%prime[i] == 0)return false;
	return true;
}
bool isHuiwen(int n,int wei){
	if (wei == 0||wei==1)return true;
	int i;
	if (n /(int) pow((double)10, wei-1) == n % 10){
		n %= (int)pow((double)10, wei-1);
		n /= 10;
		if (isHuiwen(n, wei - 2))return true;
	}
	return false;
}
int main(){
	getPrime();
	prime[psize++]=10001;
	scanf("%d%d", &from, &to);
	if (from == 5)printf("5\n");
	if (from <= 7 && to >= 7)printf("7\n");
	if (11 >= from && 11 <= to)printf("11\n");
	if (from < 100)from = 101;
	for (; from <= to; from++){
		if (isPrime(from) && isHuiwen(from,log10((double)from)+1))
			printf("%d\n", from);
	}
	return 0;
}

东大OJ-5到100000000之间的回文质数的更多相关文章

  1. P1217 [USACO1.5]回文质数 Prime Palindromes(求100000000内的回文素数)

    P1217 [USACO1.5]回文质数 Prime Palindromes 题目描述 因为151既是一个质数又是一个回文数(从左到右和从右到左是看一样的),所以 151 是回文质数. 写一个程序来找 ...

  2. 回文质数 USACO

    时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 因为 151 既是一个质数又是一个回文数(从左到右和从右到左是看一样的),所以 15 ...

  3. 洛谷 P1217 回文质数

    洛谷 P1217 回文质数 链接 https://www.luogu.org/problem/P1217 题目 题目描述 因为 151 既是一个质数又是一个回文数(从左到右和从右到左是看一样的),所以 ...

  4. P1217 [USACO1.5]回文质数 Prime Palindromes(stringstream,sizeof(num)/sizeof(num[0]),打表)

    题目描述 因为 151 既是一个质数又是一个回文数(从左到右和从右到左是看一样的),所以 151 是回文质数. 写一个程序来找出范围 [a,b](5≤a<b≤100,000,000)( 一亿)间 ...

  5. 【USACO 1.5.2】回文质数

    [题目描述] 因为151既是一个质数又是一个回文数(从左到右和从右到左是看一样的),所以 151 是回文质数. 写一个程序来找出范围[a,b](5 <= a < b <= 100,0 ...

  6. 回文质数 Prime Palindromes

    题目描述 因为151既是一个质数又是一个回文数(从左到右和从右到左是看一样的),所以 151 是回文质数. 写一个程序来找出范围[a,b](5 <= a < b <= 100,000 ...

  7. P1217 [USACO1.5]回文质数 Prime Palindromes

    题目描述 因为151既是一个质数又是一个回文数(从左到右和从右到左是看一样的),所以 151 是回文质数. 写一个程序来找出范围[a,b](5 <= a < b <= 100,000 ...

  8. [USACO1.5] 回文质数

    P1217  Prime Palindromes 题目描述 因为151既是一个质数又是一个回文数(从左到右和从右到左是看一样的),所以 151 是回文质数. 写一个程序来找出范围[a,b](5 < ...

  9. 洛谷 P1217 [USACO1.5]回文质数 Prime Palindromes

    P1217 [USACO1.5]回文质数 Prime Palindromes 题目描述 因为151既是一个质数又是一个回文数(从左到右和从右到左是看一样的),所以 151 是回文质数. 写一个程序来找 ...

随机推荐

  1. andriod 动态设置TextView 和 RelativeLayou 高度

    XML布局 <RelativeLayout android:id="@+id/rlay_meeting_contact_context" android:layout_wid ...

  2. 举例讲解Linux系统下Python调用系统Shell的方法

    有时候难免需要直接调用Shell命令来完成一些比较简单的操作,比如mount一个文件系统之类的.那么我们使用Python如何调用Linux的Shell命令?下面来介绍几种常用的方法:1. os 模块 ...

  3. Keil代码中for循环延时问题

  4. Windows批处理:自动检查服务器连通性

    该技术与上一篇<自动检查网络连通性>的实现原理相同,我将脚本稍微改动了下,用于检查公司服务器的连通性,简单快捷.在这里附上修改方法. @echo off color 1F title 服务 ...

  5. Device ehth0 is not present

    context: 使用virtualbox 克隆了一个新硬盘,然后配为新建虚机的使用,但ifconfig只能发现lo,没有eth0 解决方案: 当前系统是centos6.6 cd /etc/udev/ ...

  6. 大话设计模式C++版——原则和引言

    转贴请注明转自:http://blog.csdn.net/gufeng99/article/details/45832711 读程杰的<大话设计模式>有一段时间了,将其C#版的设计模式代码 ...

  7. ovirt-engine安装

    一.安装 1.更新系统 原来是centos4.5 #yum update 升级后到6.7版本. [root@localhost ~]# cat /etc/redhat-release CentOS r ...

  8. jquery实现输入框聚焦,键盘上下键选择城市

    在最近有个项目中 需要实现当文本框聚焦的时候,可以键盘上下键选择内容,按enter键的时候,把内容传到输入框中,如图所示: 实现代码如下: /** *输入框聚焦,键盘上下键选择城市 */ ;(func ...

  9. Student学生管理系统

    1.定义各个层 2.添加各个层之间的引用 DAL 层调用Model BLL层调用DAL和Model UI层调用BLL和Model层 Model层供各个层调用 3.根据数据库建立实体类,每张表对应一个实 ...

  10. webform:分页组合查询

    一个简单的分页组合查询页面 /// <summary> /// 查询方法 /// </summary> /// <param name="tsql"& ...