lymboy


私信TA

用户名:lymboy

访问量:18948

签 名:

等  级
排  名 819
经  验 3659
参赛次数 1
文章发表 30
年  龄 0
在职情况 学生
学  校 河南理工大学
专  业

  自我简介:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int isPalindrome(int num);        //判断是否是回文数
int isEqual(int num, int n);        //判断num的各个位的数字之和是否等于n
void itoa1(int num, char buff[]);    //itoa是非标准库函数,Windows可能会有, 我的环境是linux,所以不存在, 就自己写了一个

int main(void)
{
	int i;
	int n;
	int flg = 1;    //标记是否存在满足条件的回文数, 以此判断是否输出-1

	scanf("%d", &n);
	for (i=10000; i<=999999; i++)
	{
		if (isPalindrome(i) && isEqual(i, n))
		{
			printf("%d\n", i);
			flg = 0;
		}
	}
	if (flg)
	{
		printf("-1\n");
	}

	return 0;
}

int isPalindrome(int num)
{
	char str[7];
	itoa1(num, str);
	
	int i;
	int len = strlen(str);
	for (i=0; i<len/2; i++)
	{
		if (str[i] != str[len-1-i])
		{
			return 0;
		}
	}
	return 1;

}
int isEqual(int num, int n)
{
	int sum = 0;
	while (num != 0)
	{
		sum += num%10;
		num /= 10;
	}

	return sum == n;
}

void itoa1(int num, char buff[])
{
	int k = 0;
	while (num != 0)
	{
		buff[k++] = num % 10 + 48;
		num /= 10;
	}
	buff[k] = '\0';
}


 

0.0分

0 人评分

  评论区

  • «
  • »