iostream-C++怎么使用递归实现数组前N个元素倒序输出

问题描述

C++怎么使用递归实现数组前N个元素倒序输出

顺便看一下这个该怎么改

 #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_

时间: 2024-11-05 20:26:17

iostream-C++怎么使用递归实现数组前N个元素倒序输出的相关文章

数组的倒序输出是意思?要排序吗?还是简单的从尾到前输出??

问题描述 数组的倒序输出是意思?要排序吗?还是简单的从尾到前输出??定义一个int数组,请倒序输出所有的元素 解决方案 解决方案二:数组的倒序输出,不要排序,就是从后往前输出的意思如果要数组中元素倒序输出的话,那就要先排序,然后再根据要求输出了解决方案三:那这个题目呢??解决方案四:数组顺序输出从第0个元素,输出到第length-1个元素倒序输出从第length-1个元素到第0个元素解决方案五:加油,

c++-C++的递归实现数组中的前n个元素实现倒序输出的问题

问题描述 C++的递归实现数组中的前n个元素实现倒序输出的问题 请问以下程序有什么问题 #include <iostream> using namespace std; void fun(int str1[], int a); int main() { int str[101]; for(int i=0;i<=101;) { str[i] = i-1; } int n; cin >> n; fun(str, n); return 0; } void fun(int str1[

PHP中使用递归替换数组中的内容

PHP开发小技巧实例程序,使用递归替换数组中的内容. <?php $arr = array("<小刚>","<小晓>","<小飞>","<小李>","<小红>"); function arrContentReplact($array) { if(is_array($array)) { foreach($array as $k => $v

php 用递归遍历数组多维数

问题描述 php 用递归遍历数组多维数 Array ( [dir] => Array ( [F:开发测试 est9.14香奈儿1-10] => Array ( [dir] => Array ( [F:开发测试 est9.14香奈儿1-102362_G_1338059108234.jpg] => Array ( [file] => Array ( [0] => F:开发测试 est9.14香奈儿1-102362_G_1338059108234.jpg20120526190

PHP递归调用数组值并用其执行指定函数的方法_php技巧

本文实例讲述了PHP递归调用数组值并用其执行指定函数的方法.分享给大家供大家参考.具体分析如下: 以下为wordpress原代码,为了偷懒,简单修改一下以适用其它函数 /** * Navigates through an array and removes slashes from the values. * * If an array is passed, the array_map() function causes a callback to pass the * value back t

求数组元素的全排列,数组不含重复元素

Permutations Given a collection of numbers, return all possible permutations. For example, [1,2,3] have the following permutations:     [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], and [3,2,1]. 求数组元素的全排列,数组不含重复元素 算法1:递归 类似于DFS的递归. 对于包含n个元素的数组,先确定第一位置

[经典面试题]排序数组中绝对值最小元素

[题目] 题目为: 有一个已经排序的数组(升序),数组中可能有正数.负数或0,求数组中元素的绝对值最小的数,要求,不能用顺序比较的方法(复杂度需要小于O(n)),可以使用任何语言实现 例如,数组{-20,-13,-4, 6, 77,200} ,绝对值最小的是-4. [分析] 给定数组是已经排好序的,且是升序,没有重复元素. 一个简单的思路,就是一次性遍历数组,求出数组的元素的绝对值的最小值,这样的时间复杂度为O(n). 但是,这样就浪费了题目的一个条件:数组是已经排好序的.所以,需要对原来的题目

php array_walk 对数组中的每个元素应用用户自定义函数详解_php实例

php array_walk 对数组中的每个元素应用用户自定义函数 array_walk 使用用户自定义函数对数组中的每个元素做回调处理 基本语法 bool array_walk ( array &$array , callable $funcname [, mixed $userdata = NULL ] ) 将用户自定义函数 funcname 应用到 array 数组中的每个单元. array_walk() 不会受到 array 内部数组指针的影响. array_walk() 会遍历整个数组

javascript数组操作(创建、元素删除、数组的拷贝)_基础知识

1.数组的创建 复制代码 代码如下: var arrayObj = new Array(); //创建一个数组var arrayObj = new Array([size]); //创建一个数组并指定长度,注意不是上限,是长度var arrayObj = new Array([element0[, element1[, ...[, elementN]]]]); 创建一个数组并赋值 要说明的是,虽然第二种方法创建数组指定了长度,但实际上所有情况下数组都是变长的,也就是说即使指定了长度为5,仍然可以