码迷,mamicode.com
首页 > 其他好文 > 详细

整型反序

时间:2015-07-04 16:44:57      阅读:115      评论:0      收藏:0      [点我收藏+]

标签:华为上机题

简要描述:给出一个不多于5位的整数, 进行反序处理

要求:

1、求出它是几位数

2、分别输出每一位数字

3、按逆序输出各位数字,例如原数为321,应输出123(仅数字间以空格间隔, 负号与数字之间不需要间隔)

 

例如:输入:12345

  输出:5

1 2 3 4 5

54321

 

注意:如果是负数,负号加在第一个数字之前, 与数字没有空格间隔

比如

       输入:-12345

       输出:5

-1 2 3 4 5

-54321

 

 

函数原型:

/*
输入:
 iInput: 位数不大于5的整数

输出:
 iNum:   整数位数 
 strRst: 空格间隔输出结果
 iOutput:逆序整数

返回:
 0  成功
 -1 输入无效
*/

int ProcessX(int iInput, int& iNum, char * strRst, int& iOutput) 

#include <stdlib.h>
#include "oj.h"


/*
功能:
	给出一个不多于5位的整数,
	要求:
		1、求出它是几位数 
		2、分别输出每一位数字 
		3、按逆序输出各位数字,例如原数为321,应输出123
输入:
	整型 iInput,位数不大于5的整数

输出:
    整数位数		iNum
	空格间隔输出结果    strRst
	逆序整数		iOutput

返回:
	0  成功
	-1 输入无效
*/


int ProcessX(int iInput, int& iNum, char * strRst, int& iOutput)
{

    if(iInput>99999||iInput<-99999)
		return -1;

	iNum=0;
	iOutput=0;
    int temp=0;
    //输入为0
	if(iInput==0)
	 {
	   iNum=1;
       strRst[0]='0';
	   strRst[1]='\0';
	   iOutput=0;
	 }
	 else if(iInput>0)
	 {
	    int temp=iInput;
       	while(temp>0)
	    {
	     iOutput=iOutput*10+temp%10;
         iNum++;
	     temp=temp/10;
	     }
	  
		  int t=0;

		  temp=iOutput;
		 while(temp>0)
		 {
		   strRst[t++]=temp%10+'0';
		   strRst[t++]=' ';
		   temp=temp/10;

		 }
		 strRst[--t]='\0';
	 }
	 else if(iInput<0)
		{
			iInput=-iInput;

		 int temp=iInput;
		  while(temp>0)
		  {
		   iOutput=iOutput*10+temp%10;
	       iNum++;
		   temp=temp/10;
		  }
		  iOutput=-iOutput;
		 
		  int t=1;

		  temp=-iOutput;

		 strRst[0]='-';
		 while(temp>0)
		 {
		   strRst[t++]=temp%10+'0';
		   strRst[t++]=' ';
	      temp=temp/10;
		 }
		strRst[--t]='\0';
	}

	return 0;
}






版权声明:本文为博主原创文章,未经博主允许不得转载。

整型反序

标签:华为上机题

原文地址:http://blog.csdn.net/persever/article/details/46755587

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!