hdu1282

本题可以用字符串、数字进行解决。

由于本人对于字符串不太熟悉,于是选择对数字进行处理进行操作

#include<stdio.h>
#include<math.h>
#include<string>
#include<cstring>
#include<string.h>
#include<algorithm>
#include<iostream>
using namespace std;
bool hui(int a, int &t)//判断是否为回文数,不是则返回数字的逆序数
{
	int i;
	int temp = a;
	t = 0;
	while(a>0){
		t = t*10 + a%10;
		a /= 10;
	}
	return temp == t;
}
int main() {
	int num, v[200], count, temp, i;
	while(scanf("%d",&num)!=EOF){
		v[0] = num;
		count = 0;//记录个数
		while(1){
			if(hui(num, temp))
				break;
			else//不是回文数进行的操作
			{
				num += temp;
				count++;
				v[count] = num;
				
			}
		}
		cout << count << endl;
		cout << v[0];
		for(i=1; i<=count; i++)
			cout << "--->" << v[i];
		cout << endl;
	}
	return 0;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值