题目描述:
完成函数IsPrime(int x)和函数Reverse(int x)。函数IsPrime(x)用于判断整数x是否为素数;函数Reverse(x)用于求整数x反序数(即将各位数字的顺序倒过来)。在main()函数中输入2个正整数m和n分别作为区间的上、下界,调用函数IsPrime(x)和函数Reverse(x)求[m, n]区间内所有可逆素数(即一个素数的反序数也是素数),并按从小到大的次序输出。
输入1行,包含2个整数,即正整数m和n,两个整数之间用空格隔开。
输出1行,包含多个整数,每个整数之间用空格隔开。
输入:10 50
输出:11 13 17 31 37
输入:700 1000
输出:701 709 727 733 739 743 751 757 761 769 787 797 907 919 929 937 941 953 967 971 983 991
我的代码,上面这两个输入和输出都是正确的,
但是,
帮忙看看问题
help!
谢谢你
#include <stdio.h>
int IsPrime(int x)
{
int j,t=1;
for(j=2;j<x;j++)
{
if((x%j)==0)
t=0;
}
if(t==0) return 0;
return 1;
}
int Reverse(int x)
{
int j,t;
int a,s=0;
while(x)
{
a=x%10;
s=s*10+a;
x/=10;
}
for(j=2;j<s;j++)
{
if((s%j)==0)
t=0;
}
if(t==0) return 0;
return 1;
}
int main()
{
int m,n,i;
scanf("%d%d",&m,&n);
for(i=m;i<=n;i++)
{
if(IsPrime(i)==1)
{
if(Reverse(i)==1) printf("%d ",i);
}
}
return 0;
}