C++循环结构——回文质数

该程序旨在找出[5, 100,000,000]区间内的回文质数。首先检查回文性,然后判断是否为质数。回文数的判断考虑了偶数位的情况,而质数判断排除了2和3的倍数。" 79027649,6198587,QT、MFC与JAVA:开发环境的比较与选择,"['MFC', 'JAVA', 'QT', '编程语言', '开发工具']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

因为 151 既是一个质数又是一个回文数(从左到右和从右到左是看一样的),所以 151 是回文质数。

写一个程序来找出范围 [a,b](5≤a<b≤100,000,000)( 一亿)间的所有回文质数。

输入格式

第 1 行: 二个整数 a 和 b .

输出格式

输出一个回文质数的列表,一行一个。

分析:

先判断回文,偶数位的回文除了11都不是质数,如果b大于9999999,只要判断到9999999就可以。如果是回文数在判断素数,能被2和3整除的都不是素数,同时满足即是回文又是素数的输出。

#include<bits/stdc++.h>
using namespace std;

int huiwen(int n) {//判断回文
	int m = n;
	int i = 0;
	if (n > 11 && n < 99) {//如果是偶数位则直接返回0
		return 0;
	}
	if (n > 1000 && n < 9999) {
		return 0;
	}
	if (n > 100000&& n < 999999) {
		return 0;
	}
	if (n > 10000000 && n < 999999) {
		return 0;
	}
	if (n > 11 && n < 99) {
		return 0;
	}
	if (n > 1111 && n < 9999) {
		return 0;
	}
		while (m > 0) {
			i = i * 10 + m % 10;
			m = m / 10;
		}
		if (i 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值