解题思路:数字转换为字符串 倒置和判断回文两个函数 

注意事项:

参考代码:

#include "stdio.h"

#include "string.h"

#include "stdlib.h"

void NIZHI(char NUM[100]) //倒置

{

char a[100];

int h = strlen(NUM);

int j = 0;

for (int i = h - 1; i >= 0; i--) 

{

a[j] = NUM[i]; j++;

}

a[j] = '\0';

strcpy(NUM, a);

}

int HUIWEN(char NUM[100])//回文

{

int h = strlen(NUM);

for (int i = 0; NUM[i] != '\0'; i++)

{

if (NUM[i] == NUM[h - 1]) { h--; continue; }

if (NUM[i] != NUM[h - 1]) { break; }

}

if (h == 0) { return 1; }

if (h != 0) { return 0; }

}

int main() 

{

int p; scanf("%d", &p); 

for (int j = 0; j < p; j++)

{

int n;

scanf("%d", &n);

int k = 0;

while (1)

{

char NUM[100];

int h;

h = sprintf(NUM, "%d", n);//数字转换为字符

if (HUIWEN(NUM) == 1)

{

printf("%d\n", k); break;

}

if (HUIWEN(NUM) == 0)

{

int x;

x = atoi(NUM);

NIZHI(NUM);

x += atoi(NUM);//变回数字

n = x;

k++;

}

if (k > 8) { printf("0\n"); break; }


}

}

}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论