| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 348 人关注过本帖
标题:该程序是怎么运行的?
只看楼主 加入收藏
downeychou
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2013-11-13
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:2 
该程序是怎么运行的?
这是用递归发将一个整数n转化成字符串。例如输入354 应输出字符串“354”  n的位数不确定。
程序代码:
#include <iostream>
using namespace std;
int main()
{void convert(int n);

 int number;

 cout<<"input a number:";

 cin>>number;

 cout<<"output:"<<endl;

 if(number<0)

 {cout<<"-";
  number=-number;

 }

 convert(number);

 cout<<endl;

 return 0;
}
void convert(int n)
{ int i;

 char c;

 if((i=n/10)!=0)
     convert(i);

 c=n%10+'0';

 cout<<" "<<c;
}
例如我输入354,形参n的值为354,i为35,且不等于0,此时再调用一次convert函数,将35赋给形参n,然后i=3仍不为0,然后再调用一次convert函数,此时形参n=3,i=0所以输出 c=n%10+‘0'; 输出3;然后后面的该怎么运行?
还有c=n%10+‘0’; 这个 +‘0’是不是就是将c由数字转化成字符的过程?
谢谢。
搜索更多相关主题的帖子: number 字符串 color 
2013-11-20 08:38
peach5460
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:武汉
等 级:贵宾
威 望:30
帖 子:2780
专家分:6060
注 册:2008-1-28
收藏
得分:0 
shi

我总觉得授人以鱼不如授人以渔...
可是总有些SB叫嚣着:要么给代码给答案,要么滚蛋...
虽然我知道不要跟SB一般见识,但是我真的没修炼到宠辱不惊...
2013-11-20 08:39
a592963144
Rank: 2
等 级:论坛游民
帖 子:41
专家分:95
注 册:2013-9-27
收藏
得分:20 
个人理解 希望对楼主有帮助
调用了convert(number);之后 要执行的 每一步是这样的:
void convert(354)
{
   int i;
   char c;
   if((i=354/10)!=0)//条件判断是对的 要调用convert(i);即convert(35);
   {   void  convert(35)
       {
            int i;
            char c;
            if((i=35/10)!=0)//条件判断是对的 要调用convert(i);即convert(3);
            {
               void  convert(35)
               {
                   if((i=3/10)!=0)//条件判断是错的 不需要调用convert(i);直接执行if下边的语句
                    c=n%10+'0';   //这里n=3,得到c=3
                    cout<<" "<<c; //输出第一个值 3
               }
              c=n%10+'0';//这里n=35,得到c=5;
              cout<<" "<<c;//输出第二个值 5
         }   
   c=n%10+'0';//这里n=354,得到c=4
   cout<<" "<<c;//输出第三个值 4
}
至于c=n%10+'0';我也不是很明白,应该是把数字转化为字符(与自身数字相同)的语句。。。。。希望有大神给详解。。。。
2013-11-20 11:55
快速回复:该程序是怎么运行的?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.031997 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved