回文数的算法应该没错,运行起来好像循环没结束

输出不小于n的最小回文数。

提示:回文数是指正序逆序相等的整数,如1221,343,666等

输入

输入正整数m表示待测试的数据组数,随后m行即为组测试数据,每组数据为一个非负整数n。

#include 
int main()
{
    int num, m =0, s,tmp ,i,k,n;
    scanf("%d",&k);
    for(i=0;iscanf("%d",&num);
do{
       s = num;
       tmp=num;
    while(s!=0)
    {
        n = s%10;   
        m = m*10 +n; 
        s = s/10;  
    }
    ++num;
}while(tmp!=m);
    printf("%d\n",m);
}
    return 0;
}

循环没有结束的原因是m没有在判断第一个输入的数以后没有初始化为0,一直累加了前面的计算,所以导致出错了;在第9行后,增加一行初始化m为0的代码即可,修改如下:


#include <stdio.h>
int main()
{
    int num, m =0, s,tmp ,i,k,n;
    scanf("%d",&k);
    for(i=0;i<k;i++)
    {
        scanf("%d",&num);
        
        do{
            m=0;
            s = num;
            tmp=num;            
            while(s!=0)
            {
                n = s%10;   
                m = m*10 +n; 
                s = s/10;  
            }
            ++num;
        }while(tmp!=m);
        printf("%d\n",m);
    }
        return 0;
}
 

img


#include<stdio.h>
int main(){
    int i,j,input;
    int num[100];
    printf("Example Input\n");
    scanf("%d",&input);
    for(i=0;input>0;i++){
        num[i]=input%10;        //每位放进数组
        input=input/10;
    }
    for(j=0;j<i/2;j++){
        if(num[j]!=num[i-j-1]) break;    //两边比较
    }
    i/2==j?printf("Example Output\ntrue"):printf("Example Output\nfalse");
    return 0;
}