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

用递归法将一个整数n转换成字符串。例如,输人483,应输出字符串483。n的位数不确定,可以是任意位数的整数

时间:2020-07-22 20:37:57      阅读:91      评论:0      收藏:0      [点我收藏+]

标签:运行   数位   return   put   loading   lan   void   out   integer   

用递归法将一个整数n转换成字符串。例如,输人483,应输出字符串”483”。n的位数不确定,可以是任意位数的整数

题目解析:

递归法求解主要要有结束条件,此题为n/10 == 0时就直接输出,其次本题还要考虑如果整数位负数的情形,此时需要输出一个字符串的负号。

#include<stdio.h>

void Convert(int n)
{
	int i;
	if ((i = n / 10) != 0)
		Convert(i);
	putchar(n % 10 + ‘0‘);
}

int main()
{
	int number;
	printf("input an integer: ");
	scanf("%d", &number);
	printf("output: ");
	if (number < 0)
	{
		putchar(‘-‘);   //先输出一个负号‘-‘
		number = -number;
	}
	Convert(number);
	printf("\n");
	return 0;
}

运行结果:

技术图片

用递归法将一个整数n转换成字符串。例如,输人483,应输出字符串483。n的位数不确定,可以是任意位数的整数

标签:运行   数位   return   put   loading   lan   void   out   integer   

原文地址:https://www.cnblogs.com/inta/p/13362523.html

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