整型反序

描述:
给出一个不多于5位的整数,进行反序处理,要求:1、求出它是几位数;2、分别输出每一位数字;3、按
逆序输出各位数字,例如原数321,应输出123(仅数字之间以空格间隔,负号与数字之间不需要间隔)
例如:输入:12345 输出 5 ; 1 2 3 4 5 ; 54321
注意:如果是负数,负号加在第一个数字之前,与数字没有空格间隔,比如:输入:-12345 输出:5;-1 2 3 4 5;-54321


分析:
对于一个整数,可先用取余,除以10的方法得出位数,同时可以顺便得出逆序整数,如果是负数,逆序整数要乘以(-1);
得出逆序整数后,再用取余,除以10的方法,可以将出原数的每一位输出。总结起来就是: 位数->逆序整数->原数位数输出


代码如下:
int ProcessX (int iInput, int& iNum, char * strRst, int& iOutput)
{
bool isneg = false;
int k = 0;
iNum = 0;
iOutput = 0;

if (iInput < 0)
{
isneg = true;
iInput = (-1)*iInput;
}
int temp = iInput;
do
{
iNum++;
if (iNum > 5)
{
return -1;
}
iOutput = iOutput * 10 + temp%10;
temp = temp/10;
}
while(temp);

if (isneg)
{
iOutput = (-1)*iOutput;
strRst[k++] = '-';
}
temp = abs(iOutput);
for (int i=0; i< iNum; i++)
{
strRst[k++] = temp %10 + '0';
temp = temp /10;
if (i < iNum - 1)
{
strRst[k++] = ' ';
}
}
return 0;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值