设为首页 加入收藏

TOP

整型反序
2014-03-10 12:52:53 来源: 作者: 【 】 浏览:96
Tags:

   描述:

  给出一个不多于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;

  }

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇C++ 虚基类构造函数的执行顺.. 下一篇一个裸的KM算法实例详解

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Libevent C++ 高并发 (2025-12-26 00:49:30)
·C++ dll 设计接口时 (2025-12-26 00:49:28)
·透彻理解 C 语言指针 (2025-12-26 00:22:52)
·C语言指针详解 (经典 (2025-12-26 00:22:49)
·C 指针 | 菜鸟教程 (2025-12-26 00:22:46)