张麻子


私信TA

用户名:qwezjh

访问量:3033

签 名:

上任鹅城

等  级
排  名 881
经  验 3554
参赛次数 0
文章发表 25
年  龄 0
在职情况 学生
学  校 asd
专  业

  自我简介:

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

注意事项:

参考代码:

#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 人评分

  评论区

  • «
  • »