定理与猜想(回文数的形成)

本文介绍了一个通过将任意十进制整数与其反序数相加直至得到回文数的算法验证过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/**************************************** 
*  File Name  : figure.c 
*  Creat Data : 2015.1.30
*  Author     : ZY 
*****************************************/ 

/*定理与猜想*/
/*回文数的形成*/
/*任取一个十进制整数,将其倒过来后与原来的整数相加,
得到一个新的整数后重复以上步骤,则最终可得到一个回文数
,请编程验证*/


#include <stdio.h>
#define MAX 2147483647//限定M+N的范围
int long re(long a)//将整数反序
{
	long t;
	for(t = 0;a > 0;a /= 10)
	{
		t = t*10+a%10;
	}
	return t;
}
int nonre(long s)//判断是否是回文数
{
	if(re(s) == s)
	{
		return 1;
	}
	else
	{
		return 0;
	}
}
int main(void)
{
	long n ,m;
	int count = 0;
	printf("please enter a number optionaly:");
	scanf("%ld",&n);
	printf("The generation process of palindrpme:\n");
	while(!nonre((m = re(n))+n))//判断整数与其反序数相加后是否为回文数
	{
		if(m+n >= MAX)//超过界限输出提示信息
		{
			printf("input error,break.\n");
			break;
		}
		else
		{
			printf("[%d]:%ld+%ld = %ld\n",++count,n,m,m+n);
			n += m;//累加
		}
	}
	printf("[%d]:%ld+%ld = %ld\n",++count,n,m,m+n);
	//输出最后的回文数
	printf("Here we reached the aim at last!\n");
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值