c++算法实现(一) - 递归和初始化
递归
写递归函数经常出错,提醒自己两个规则:
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++算法实现(一) - 递归和初始化的更多相关文章
- 算法基础_递归_求杨辉三角第m行第n个数字
问题描述: 算法基础_递归_求杨辉三角第m行第n个数字(m,n都从0开始) 解题源代码(这里打印出的是杨辉三角某一层的所有数字,没用大数,所以有上限,这里只写基本逻辑,要符合题意的话,把循环去掉就好) ...
- Java实现 蓝桥杯VIP 算法训练 非递归(暴力)
试题 算法训练 非递归 问题描述 当x>1时,Hermite多项式的定义见第二版教材125页.用户输入x和n,试编写"非递归"函数,输出对应的Hermite多项式的值.其中x ...
- C#算法基础之递归排序
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- 汉诺塔(河内塔)算法 ----C语言递归实现
汉诺塔:汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具.大梵天创造世界的时候做了三根金刚石柱子, 在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘.大梵天命令婆罗门把圆盘从下面开始按大小顺 ...
- 算法打基础——符号&递归解法
第二节 算法复杂度分析的的基本符号及 递归关系式下的复杂度解法 这次的主要知识点是: 1.各种复杂度符号 2.递归复杂度解法: 分为三种 替换法(猜!) 递归树法 主定理 1各种复杂度符号 ...
- 算法笔记_017:递归执行顺序的探讨(Java)
目录 1 问题描述 2 解决方案 2.1 问题化简 2.2 定位输出测试 2.3 回顾总结 1 问题描述 最近两天在思考如何使用蛮力法解决旅行商问题(此问题,说白了就是如何求解n个不同字母的所有不同排 ...
- 【PyQt】算法-插入、递归、冒泡
# coding=utf-8 import sys from PyQt4.QtGui import * from PyQt4.QtCore import * class MainWindow(QMai ...
- [图解算法] 归并排序MergeSort——<递归与分治策略>
#include"iostream.h" void Merge(int c[],int d[],int l,int m,int r){ ,k=l; while((i<=m)& ...
- python 下的数据结构与算法---5:递归(Recursion)
定义:递归就是不断分割整体成部分直到可以轻易解决分割出来的部分. 递归表达式三定律: 1:递归表达式必须有个最小单元 (最小单元既是停止递归调用以及能够直接运算的) 2:递归表达式在运算过程中 ...
随机推荐
- mysql Navicat 导入导出
1.导出数据库: 打开Navicat ,在我们要导出的数据库上右击鼠标,然后弹出的快捷菜单上点击“转储SQL 文件”,(有些版本, 会有子菜单,在再次弹出的子菜单项中选择第一个“数据跟结构”) ...
- [LeetCode] N-ary Tree Postorder Traversal N叉树的后序遍历
Given an n-ary tree, return the postorder traversal of its nodes' values. For example, given a 3-ary ...
- cpu读取指令时读取的长度
CPU读取指令时,如果单字节指令,一次访存即可完成读取操作:如果是多字节指令,会根据第一次读取指令的操作码与寻址标志位,判断指令的后续长度,进而完成整个指令的读取,同时指令指针IP会自动进行修改,指向 ...
- js中函数创建的三种方式
1.函数声明 function sum1(n1,n2){ return n1+n2; }; 2.函数表达式,又叫函数字面量 var sum2=function(n1,n2){ re ...
- Ehcache 3.7文档—基础篇—Tiering Options
Ehcache支持分层缓存的概念,这节主要介绍不同的配置选项,同时也解释了规则和最佳实践. 一. 数据缓存到堆外 当在cache中除了有heap层之外,有一些需要注意的: 添加一个key-value到 ...
- day 23 二十三、对象方法,类方法,封装,绑定方法
一.对象的特有名称空间 __init__方法会在实例化对象时被调用 1.会为实例化的对象形成空的名称空间 2.就是一个方法,可以被传参,在类名(实参)这种方式下调用并传参 __init__(self ...
- Integer、new Integer() 和 int 比较的面试题
基本概念的区分: 1.Integer 是 int 的包装类,int 则是 java 的一种基本数据类型2.Integer 变量必须实例化后才能使用,而int变量不需要3.Integer 实际是对象的引 ...
- 使用sysbench压测磁盘io
Ⅰ.sysbench安装 cd /usr/local/src yum -y install make automake libtool pkgconfig libaio-devel git clone ...
- 三报文握手 四报文握手 TCP运输连接管理
三报文握手 四报文握手 TCP运输连接管理
- CSCI 1100 — Computer Science 1 Homework
CSCI 1100 — Computer Science 1 Homework 8CS1 Multiverse: ClassesOverviewThis homework is worth 100 p ...