递归

写递归函数经常出错,提醒自己两个规则:

1. 一般来说递归函数中不应该出现for、while之类的循环语句, 因为递归就是循环的另外一种实现;

2. 注意基线条件,具体参考《算法图解》p32。

一个死循环的递归:

    void recurCreate(TreeNode* p, vector<int>& vec, int l, int r){
while (l<r) {
int m = l+(r-l)/;
p = new TreeNode(vec[m]);
recurCreate(p->left, vec, l, m);
recurCreate(p->right, vec, m+, r);
}
}

正确的写法:

    void recurCreate(TreeNode* p, vector<int>& vec, int l, int r){
if (l>=r) return;
else {
int m = l+(r-l)/;
p = new TreeNode(vec[m]);
recurCreate(p->left, vec, l, m);
recurCreate(p->right, vec, m+, r);
}
}

指针初始化

TreeNode* sortedArrayToBST(vector<int> &nums) {
if(nums.size()==) return nullptr;
TreeNode* root = new TreeNode(); //新建一个树节点,同时在内存中分配一个地址给它,root指向该地址
TreeNode* root1; //root1指向八荒之外的某个地址(未初始化局部变量,应避免此操作)
root1->val = ;
TreeNode* root2 = nullptr; //root2是个空指针,没有指向哪里
root1->val = ; //空指针是没有内容的,因此这里调用nullptr->val是错的 错的 错的
recurCreate(root, nums, , static_cast<int>(nums.size()) ); //递归建立BST,返回root地址
recurCreate(root1, nums, , static_cast<int>(nums.size()) ); //root1里啥也没有
recurCreate(root1, nums, , static_cast<int>(nums.size()) );
return root;
}

未初始化变量的问题参考:C/C++中已初始化/未初始化全局/静态/局部变量/常量在内存中的位置

备注:

本是毫不相关的两个问题,刚好在同一道题里遇到了,leetcode108,完整代码如下:

class Solution {
public:
void recurCreate(TreeNode* p, vector<int>& vec, int l, int r){
if (l>=r) {
return;
}
else {
int m = l+(r-l)/;
p->val = vec[m];
if(l<m){
p->left = new TreeNode();
recurCreate(p->left, vec, l, m);
}
if(m+<r){
p->right = new TreeNode();
recurCreate(p->right, vec, m+, r);
}
}
}
TreeNode* sortedArrayToBST(vector<int> &nums) {
if(nums.size()==) return nullptr;
TreeNode* root = new TreeNode();
recurCreate(root, nums, , static_cast<int>(nums.size()) );
return root;
}
};

c++算法实现(一) - 递归和初始化的更多相关文章

  1. 算法基础_递归_求杨辉三角第m行第n个数字

    问题描述: 算法基础_递归_求杨辉三角第m行第n个数字(m,n都从0开始) 解题源代码(这里打印出的是杨辉三角某一层的所有数字,没用大数,所以有上限,这里只写基本逻辑,要符合题意的话,把循环去掉就好) ...

  2. Java实现 蓝桥杯VIP 算法训练 非递归(暴力)

    试题 算法训练 非递归 问题描述 当x>1时,Hermite多项式的定义见第二版教材125页.用户输入x和n,试编写"非递归"函数,输出对应的Hermite多项式的值.其中x ...

  3. C#算法基础之递归排序

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  4. 汉诺塔(河内塔)算法 ----C语言递归实现

    汉诺塔:汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具.大梵天创造世界的时候做了三根金刚石柱子, 在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘.大梵天命令婆罗门把圆盘从下面开始按大小顺 ...

  5. 算法打基础——符号&递归解法

    第二节 算法复杂度分析的的基本符号及 递归关系式下的复杂度解法 这次的主要知识点是: 1.各种复杂度符号  2.递归复杂度解法: 分为三种 替换法(猜!)   递归树法    主定理 1各种复杂度符号 ...

  6. 算法笔记_017:递归执行顺序的探讨(Java)

    目录 1 问题描述 2 解决方案 2.1 问题化简 2.2 定位输出测试 2.3 回顾总结 1 问题描述 最近两天在思考如何使用蛮力法解决旅行商问题(此问题,说白了就是如何求解n个不同字母的所有不同排 ...

  7. 【PyQt】算法-插入、递归、冒泡

    # coding=utf-8 import sys from PyQt4.QtGui import * from PyQt4.QtCore import * class MainWindow(QMai ...

  8. [图解算法] 归并排序MergeSort——<递归与分治策略>

    #include"iostream.h" void Merge(int c[],int d[],int l,int m,int r){ ,k=l; while((i<=m)& ...

  9. python 下的数据结构与算法---5:递归(Recursion)

    定义:递归就是不断分割整体成部分直到可以轻易解决分割出来的部分. 递归表达式三定律: 1:递归表达式必须有个最小单元     (最小单元既是停止递归调用以及能够直接运算的) 2:递归表达式在运算过程中 ...

随机推荐

  1. python进阶篇

    python进阶篇 import 导入模块 sys.path:获取指定模块搜索路径的字符串集合,可以将写好的模块放在得到的某个路径下,就可以在程序中import时正确找到. ​ import sys ...

  2. [LeetCode] Kth Largest Element in a Stream 数据流中的第K大的元素

    Design a class to find the kth largest element in a stream. Note that it is the kth largest element ...

  3. [Educational Round 5][Codeforces 616F. Expensive Strings]

    这题调得我心疲力竭...Educational Round 5就过一段时间再发了_(:з」∠)_ 先后找了三份AC代码对拍,结果有两份都会在某些数据上出点问题...这场的数据有点水啊_(:з」∠)_[ ...

  4. JavaScript学习day2 (基本语法上)

    知识点 JavaScript 的变量 数据类型 运算符 JavaScript 的动态类型 变量:(变量的命名规则和其他语言类似) 由数字,字母,下划线组成,区分大小写 以字母开头 变量名不能有空格 不 ...

  5. myeclipse使用git图文教程

    Git介绍与使用 1.什么是Git Git是分布式版本控制系统 Git是一款免费.开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. 2.集中式版本控制系统(CVS / SVN等) 集中 ...

  6. viewport的故事(二)

     挑重点的翻译 自原文 https://www.quirksmode.org/mobile/viewports2.html   在这一页我们将聊一聊移动端的浏览器.   移动端的问题   最明显的问题 ...

  7. Spring-Boot 使用 Jedis 操作 Redis

    背景: 1.Redis 之前学了个皮毛 还忘的差不多了,感觉公司项目中的Redis用的真的牛逼,so 需要深造. 2.有个同事在搞Jedis,勾起了我对知识的向往,不会用,但是很渴望. 过程: 1.改 ...

  8. Gym 101606B - Breaking Biscuits - [凸包+旋转卡壳][凸包的宽度]

    题目链接:https://codeforces.com/gym/101606/problem/B 题解: 对于给出的 $n$ 个点,先求这些点的凸包,然后用旋转卡壳求出凸包的宽度(Width (min ...

  9. Jmeter-----图形扩展监控

    Jmeter----图形扩展监控 监听器中插件安装成功如下图: 安装步骤: 1.  下载JMeterPlugins-Extras与JMeterPlugins-Standard,解压缩后在他们各自的\l ...

  10. [Day19]Collection接口中的子类(List集合、Set集合)

    1.List接口 1.1API总结 (1)是一个元素存取有序的集合 (2)是一个带有索引的集合,通过索引可以精确的操作集合中的元素 (3)集合中有可以重复的元素,通过元素的equals方法,来比较是否 ...