c语言问题 可逆素数啊

题目描述:
完成函数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
我的代码,上面这两个输入和输出都是正确的,
但是,

img


帮忙看看问题
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;
}


Reverse里的t没有初值

#include <stdio.h>
int IsPrime(int x)
{
        int j;
    if(x<2)
        return 0;
       for(j=2;j*j<=x;j++)
      {    
        if((x%j)==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;
    } 
 return s;
}
 
int main()
{
  int m,n,i,k;
  scanf("%d%d",&m,&n);
  for(i=m;i<=n;i++)
  { 
  if(IsPrime(i)==1)
    {
         k = Reverse(i);
         if(IsPrime(k))
            printf("%d ",i);
    } 
  }
  return 0;
}