算法(递归)黑盒思想

递归vs搜索vs回溯
递归的时候其实就是在搜索,递归返回的时候其实就是在回溯
常见的二叉树的题目基本都用到了递归:
求二叉树节点个数(后序遍历)

int BinaryTreeSize(BTNode* root)
{
	return root == NULL ? 0 : BinaryTreeSize(root->left) + BinaryTreeSize(root->right) + 1;

求二叉树叶子节点的个数

int BinaryTreeLeafSize(BTNode* root)
{
	if (root == NULL)
	{
		return 0;
	}
	if (root->left == NULL && root->right == NULL)
	{
		return 1;
	} 
	return  BinaryTreeLeafSize(root->left) + BinaryTreeLeafSize(root->right);
}

求二叉树第k层的节点数

int BinaryTreeLevelKSize(BTNode* root, int k)
{
	assert(k > 0);
	if (root == NULL)
	{
		return 0;
	}
	
	if (k == 1)
	{
		
		return 1;
	}
	return  BinaryTreeLevelKSize(root->left, k - 1) + BinaryTreeLevelKSize(root->right, k - 1);
}

单值二叉树的判断

bool isUnivalTree(struct TreeNode* root){
    if(root==NULL)
    {
        return true;
    }
    if(root->left&&root->left->val!=root->val)
    {
        return false;
    }
    if(root->right&&root->right->val!=root->val)
    {
        return false;
    }
       return  isUnivalTree(root->left)&&isUnivalTree(root->right);
}

经典递归算法:
找出重复子问题,相信这个递归函数一定能完成这个重复的子问题

在这里插入图片描述

汉诺塔问题 ——找出重复子问题

合并两个有序链表 ——删除某个子节点,任然可以完成递归(黑盒任务)
反转链表——递归回溯时,实现子问题函数体
两两交换链表节点——每次递归深度root->next->next

相关推荐

  1. ---算法

    2024-03-10 15:08:02       45 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-10 15:08:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-10 15:08:02       101 阅读
  3. 在Django里面运行非项目文件

    2024-03-10 15:08:02       82 阅读
  4. Python语言-面向对象

    2024-03-10 15:08:02       91 阅读

热门阅读

  1. flutter截屏的方式生成图片水印

    2024-03-10 15:08:02       41 阅读
  2. 探索云原生世界:Serverless 技术的崛起与应用

    2024-03-10 15:08:02       45 阅读
  3. 使用SVM进行评论情感分析

    2024-03-10 15:08:02       49 阅读
  4. 剑指offer-第二版

    2024-03-10 15:08:02       42 阅读
  5. 区块链基础知识01

    2024-03-10 15:08:02       45 阅读
  6. QWebEngineView添加chrome参数的方法

    2024-03-10 15:08:02       41 阅读
  7. 随机森林原理&sklearn实现

    2024-03-10 15:08:02       42 阅读
  8. 软件设计模式:模板方法模式

    2024-03-10 15:08:02       41 阅读
  9. RabbitMQ如何实现消费端限流

    2024-03-10 15:08:02       42 阅读