草庐IT

RECURSION

全部标签

c++ - 如何使 O(n) 的功能检查字母(上和下)和 ()+-*/到尾递归?

我想弄清楚如何将我创建的函数转换为检查传递的字符串,如果它只包含字母(小写或大写)并且只包含这些标点符号()+-*/....高效的递归函数,可能通过尾递归。这是我的代码:/*typedefstd::stringStringElem;*/boolverify_input_str(StringElemstr_para){for(intx=0;x谁能给我一个提示,我将不胜感激。谢谢,期待您的建议。 最佳答案 由于尾​​递归要求在递归调用之后不进行任何计算,因此这里的方法非常简单:以包含StringElement中的当前位置pos的签名开始

c++ - 将递归置换生成器转换为迭代

我在将这个用于显示给定整数集的所有排列的递归算法转换为迭代算法时遇到了一些困难。voidgetPermutationsR(intv[],intn,inti){if(i==n){//Displaycontentsofv}else{for(intj=i;j这是我目前的尝试,它是完全错误的,但如果不对问题使用native迭代算法,我看不出有任何方法可以更正它。我的一半尝试让我“弹出”多于“推送”(当我尝试访问空堆栈中的元素时导致错误),而另一半我“推送”多于“弹出”(无限循环)。voidgetPermutationsI(intv[],intn,inti){stackiStack;stackj

c++ - 我应该如何递归调用模板函数?

我正在尝试用C++创建一个树类我不确定在使用递归时应该如何使用模板。例如我有以下功能:templatevoiddestroyTree(typenameAVLTree::Node*element){if(!element){return;}destroyTree(element->getLeft());destroyTree(element->getRight());deleteelement;}或者应该是:templatevoiddestroyTree(typenameAVLTree::Node*element){if(!element){return;}destroyTree(ele

C++ 相互递归变体类型

我正在尝试使用变体在C++中表示PDF对象类型。PDF对象是以下之一:BooleanIntegerRealStringNameStreamArrayMap如您所见,Object类型是相互递归的,因为Arraytype需要声明Map需要声明Array的类型类型。我怎么能在C++中表示这种类型呢?如果变体不是最好的方法,那什么才是?这是我到目前为止尝试过的方法,但由于std::unordered_map的要求,它无法编译。(我认为)http://coliru.stacked-crooked.com/a/699082582e73376e 最佳答案

c++ - 递归STL映射

我正在尝试制作一棵map树(或者只是将一个map的值指向另一个map),但我不太确定如何处理这个问题。我发现了一个关于这个的讨论:http://bytes.com/topic/c/answers/131310-how-build-recursive-map但我对那里发生的事情有点困惑。比如我的key是一个char,我的value是下一个map。这是假设的声明:map>>>>>>>>>root_map; 最佳答案 也许你在想这样的事情:#include#includetemplatestructTree{typedefstd::map

c++ - 按升序递归输出二叉树

我当前关于如何输出我的二叉树的实现在g++中出现错误,按照Conditionaljumpormovedependsonuninitialisedvalue(s)我目前的实现是:voidFoo::output(ostream&s,constNode*p){if(p){output(s,p->left);sinfo;output(s,p->right);}}Node是一个基本的结构体,有一个左右指针和一个整型信息变量。ostream就是cout错误信息非常直接,它不喜欢我让它“跑掉”。我的问题有两个:为什么这是不合适的?什么都没有改变,我不知道它会带来什么伤害。执行此操作的正确方法是什么?

c++ - 如何将命题逻辑树转换为合取范式 (CNF) 树

我有一个类似字符串的字符串s="(=>P(OR(ANDA(NOTB))(ANDB(NOTA))))";并转换输出这个字符串的CNF,比如(或(非P)(或AB))(或(不是P)(或(不是B)(不是A)))我需要创建一个结构体TreeNode来保留值吗?structTreeNode{stringval;//Thedatainthisnode.TreeNode*left;//Pointertotheleftsubtree.TreeNode*right;//Pointertotherightsubtree.//TreeNode*farther;//shouldIusefartherornoti

c++ - 返回第 n 个斐波那契数的快速递归函数

谁能解释一下下面的代码是如何工作的。该代码作为返回第n个斐波那契数的函数的快速递归实现给出。我对递归函数的工作原理有一个大概的了解。我可以完全理解这种函数的直接递归实现,使用斐波那契数的定义,但是效率不高。我无法理解的主要问题是当我们在prev0中存储垃圾时fib(n–1,prev0)返回什么。intfib(intn,int&prev1){if(n我是初学者,所以请尽可能具体。 最佳答案 您可能错过了这个函数返回两个结果的事实:一个作为其返回值,一个在通过引用传递的“输入”参数中。fib的简单递归定义的严重低效之处在于,在每个递归级

c++ - 在递归中使用按引用传递

intf(int&x,intc){c=c-1;if(c==0)return1;x=x+1;returnf(x,c)*x;}intx=5;cout在上面的示例中,可供选择的四个可能答案是:3024656155440161051函数f(int&x,intc)在第一次调用之后被调用四次,然后到达返回结果6561的基本情况。我猜是3024但我错了。即使通过引用传递的x变量在每次调用f(int&x,intc)时递增并取值6->7->8->9分别这个递归的最终结果等于9^4。所以我的问题是:变量x是通过引用传递的,当到达基本情况时等于9。这是否意味着递归的所有阶段都将具有变量x的这个值,即使它们在

c++ - 使用存储在可变数据结构中的字段作为方法参数

我有一个可变数据结构,每个“层”包含一个字段。如何使用存储在结构中的所有字段作为函数或构造函数的参数?templateclassBuilder{};templateclassBuilder:publicBuilder{public:Builder(Tt,Ts...ts):Builder(ts...),tail(t){}Resultbuild(){//wanttousetail,Builder::tail,etc.//asctororfunctionargumentswithoutmultiplespecializations}private:constTtail;};一般来说,我希望能