C语言——回文质数

回文质数

题目详情:
在这里插入图片描述
输出范例:
在这里插入图片描述
解题思路:
输入a,b,判断a,b之间的回文质数,回文数比质数少因此先找回文数再判断是否为质数。
回文数判断
while(num1!=0){
last=num1%10;
num2=num2*10+last;
num1=num1/10;
}

#include <stdio.h>
int zs(int n){
	int i,flag=0;
	if(n<=2)//1.2是质数 
		return 1;
	else{
		for(i=2;i<n;i++){
			if(n%i==0){//不是质数 
				flag=-1;
				return -1;
				break;
			}
		} 
		return 1;//是质数 
	}
}
int main(){
	int i,t,a,b,num1,num2=0,last=0;
	scanf("%d%d",&a,&b);
	//printf("%d\n",zs(6));
	if(a>b){//确保a<b 
		t=a;
		a=b;
		b=t;
	}
	for(i=a;i<=b;i++){
		num1=i;
		while(num1!=0){
			last=num1%10;
			num2=num2*10+last;
			num1=num1/10;
		}
		if(i==num2&&(zs(i)==1)){//回文质数 
			printf("%d\n",i);
		}
		num2=0;
	}
	return 0;
}
发布了7 篇原创文章 · 获赞 6 · 访问量 95

猜你喜欢

转载自blog.csdn.net/weixin_44252790/article/details/104031387