Chinaunix首页 | 论坛 | 博客
  • 博客访问: 836688
  • 博文数量: 91
  • 博客积分: 2544
  • 博客等级: 少校
  • 技术积分: 1885
  • 用 户 组: 普通用户
  • 注册时间: 2006-12-12 09:08
文章存档

2016年(10)

2014年(2)

2013年(4)

2012年(23)

2011年(23)

2010年(13)

2009年(14)

2007年(2)

分类:

2011-03-20 11:44:43

递归
 
1, 用递归把一个十进制数转换成字符串,输出。
 
void my_itoa(unsigned int n)
{
   unsigned int v;
   v = n/10;            //取整
   if (0 != v)
      my_itoa(v);       //把余下的整数往下传,进行递归
 
   putchar(n%10 + '0'); //取值
}
 
解析:用123整数举例,传递给my_itoa函数的参数调用分别是:
my_itoa(123);  ----> 对应打印3
my_itoa(12);   ----> 对应打印2
my_itoa(1);    ----> 对应打印1
此时不在调用自身开始执行打印语句,并开始输出,传的参数分别是:123,12,1。这样打印的数分别是1,2,3。
 
由此可以推出,把一个十进制数转成2、8、16进制都可以用递归处理。
 
 
阅读(1361) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~