设为首页收藏本站

新微赢技术网

 找回密码
 注册
搜索
热搜: 回贴
查看: 1597|回复: 9
打印 上一主题 下一主题

C++初级编程的问题(一道难题)

[复制链接]
跳转到指定楼层
1#
发表于 2009-11-3 02:01:37 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
大题:用递归法将一个整数n转换成字符串。例如,输入483,应输出字符串“483”。n的位数不确定。

书上的答案是这样的:

#include<iostream>
using namespace std;
int main()
{
void convert(int n);
int number;
cout<<"input an integer:";
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;
}


问题:(1) c=n%10+'0'; 该句如何理解? +'0' 是什么意思?
(2)假如number=345,执行步骤就是
n=345 i=34
n=34 i=3
n=3 i=0
则n=34 c=…… 然后输出c
但是convert函数是如何实现“流程返回上一次函数调用处的”?返回到n=345??
2#
发表于 2009-11-3 02:01:38 | 只看该作者
c=n%10是把数字按位分离出来再加上'0'是让分离出的数字变成其对应字符串的ACSII码
回复 支持 反对

使用道具 举报

3#
发表于 2009-11-3 02:01:39 | 只看该作者
楼主在哪看到的题目啊
回复 支持 反对

使用道具 举报

4#
发表于 2009-11-3 02:01:40 | 只看该作者
如果没有c=n%10+'0';如果没有这句话输出的将不是你想要的结果,就拿你说的345来说,你想最开始输出3,但是输出的却是ACSII码为3的字符.所以必须用这句调整.
递归函数的调用,就是调用自身的函数,在输出c之前判断条件,若条件成立,则继续想下一层调用,直到条件不满足,开始返回.
这个过程实际是进栈出栈的过程.
回复 支持 反对

使用道具 举报

5#
发表于 2009-11-3 02:01:41 | 只看该作者
C++库函数可以直接做到,一行程序就可以了。
#include<iostream>
#include <sstream>
using namespace std;
int main()
{
int number;
stringstream ss;
cout<<"input an integer:";
cin>>number;
ss << number;
cout<<"output:"<< ss.str();
return 0;
}
回复 支持 反对

使用道具 举报

6#
发表于 2009-11-3 02:01:42 | 只看该作者
但是convert函数是如何实现“流程返回上一次函数调用处的”?返回到n=345?? (返回到经过一次处理后的)
通过他拉 if((i=n/10)!=0)(这句话意思是当I不是一个一位数时,条件成立)
convert(i);
楼主好象对%与/ 不是很了解
%是求余运算符 他把你给的数除以10,余下的数就是结果(你要是%3,结果就是0,1,2,中选一个多用于求范围数,例如彩票(INT%37)+1)
/简单的除号除10 但是当除完10剩下小数,因为你的数据类型是INT,所以小数被丢弃(大多用来把数最后位去掉)
回复 支持 反对

使用道具 举报

7#
发表于 2009-11-3 02:01:43 | 只看该作者
c=n%10+'0'; 该句如何理解? +'0' 是什么意思?
字符'0'与其他'1','2','3'ASCII码差值正好是0与1,2,3的差值
这样,n%10后的余数 例如是3
3+'0'就是'3'了
这里'0'可以理解为'0'的ASCII码里面的位置,位置下移3位
回复 支持 反对

使用道具 举报

8#
发表于 2009-11-3 02:01:44 | 只看该作者
第一个问题我理解了,可第2个呢?
但是convert函数是如何实现“流程返回上一次函数调用处的”?返回到n=345??
回复 支持 反对

使用道具 举报

9#
发表于 2009-11-3 02:01:46 | 只看该作者
这个问题确实不好理解,楼主的意思可能是这样.第一次在c=n%10+'0'中的n是4,照理说函数应该就此结束了,因为后面没有任何支持循环的语句,但为何又继续输出8呢,而且接着输出了3,函数的这个循环是如何实现的??循环的终止条件是什么??
回复 支持 反对

使用道具 举报

10#
发表于 2009-11-3 02:01:47 | 只看该作者
if((i=n/10)!=0)
convert(i);
c=n%10+'0';
cout<<" "<<c;
因为第一次调用过程时
到了IF那里符合条件
则convert(i);
此时函数不再继续进行
而是又进入第二个convert(i);
此时剩下48(if((i=n/10)!=0)这里i已经是n处理完的后的)
又符合if条件
继续进入convert(i);
此时剩下4.不符合if条件
这时才执行c=n%10+'0';
cout<<" "<<c;
即第一个输出为4;
因为这个函数void 所以直接回到剩下48的那个地方
然后才往下执行c=n%10+'0';
cout<<" "<<c;
即为8
然后又回到第一次调用时483,c=n%10+'0';
cout<<" "<<c;
即为3;
我解释的够详细了吧
提醒楼主一下
大题:用递归法将一个整数n转换成字符串。例如,输入483,应输出字符串“483”。n的位数不确定。
这里不是输出字符串 是单个单个输出字符 你是char c
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

申请友链|小黑屋|最新主题|手机版|新微赢技术网 ( 苏ICP备08020429号 )  

GMT+8, 2024-11-18 03:31 , Processed in 0.097766 second(s), 9 queries , Gzip On, Memcache On.

Powered by xuexi

© 2001-2013 HaiAn.Com.Cn Inc. 寰耽

快速回复 返回顶部 返回列表