顺便看一下这个该怎么改
#include <iostream>
using namespace std;
int n;
int fun(int str[]);
int main()
{
int str[101];
for(int i=0;i<=100;)
{
str[i] = i++;
}
int n;
cout << "输入:" << endl;
cin >> n;
fun(str);
return 0;
}
int fun(int str[])
{
if(n==0)
{
return 0;
}
else
{
cout << str[n];
--n;
return fun(str);//特别是这
}
}
这里return没有任何意义。
void fun(int str[])
{
if(n==0)
{
return;
}
else
{
cout << str[n];
--n;
fun(str);
}
}
本质上这是尾递归,相当于这样的代码
void fun(int str[])
{
while (n != 0) {
cout << str[n];
--n;
}
}
这样你能理解了吧。
这里return没有任何意义。
void fun(int str[])
{
if(n==0)
{
return;
}
else
{
cout << str[n];
--n;
fun(str);
}
}
本质上这是尾递归,相当于这样的代码
void fun(int str[])
{
while (n != 0) {
cout << str[n];
--n;
}
这样你能理解了吧。}
递归 简单说就是自己调用自己
还有需要一个结束条件,然后实现一次功能 就可以继续实现以后的次数
接着,朋友 推荐你本书 林锐的 C高质量编程
好的编程风格是优美如诗歌的
http://wenku.baidu.com/link?url=3D49LIuXUQWMuiBM5tDkEleMNJycGLcpt3EKF1q9HesHzrc8-oUCMRBHK95j-IU7zUV3c65KvIdPHb1H9AiNeUXtvLH_J-HakAUb3CHpkC_