当前位置: 首页 > news >正文

安徽通皖建设工程有限公司网站百度app下载官方免费下载安装

安徽通皖建设工程有限公司网站,百度app下载官方免费下载安装,wordpress后台分类目录添加自定义,开个公司一年需要多少费用给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。 叶子节点 是指没有子节点的节点。 示例 1: 输入:root [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSum 22 输出&a…

给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。

叶子节点 是指没有子节点的节点。

示例 1:

输入:root = [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSum = 22
输出:[[5,4,11,2],[5,8,4,5]]

示例 2:

输入:root = [1,2,3], targetSum = 5
输出:[]

示例 3:

输入:root = [1,2], targetSum = 0
输出:[]

代码:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*//*** Return an array of arrays of size *returnSize.* The sizes of the arrays are returned as *returnColumnSizes array.* Note: Both returned array and *columnSizes array must be malloced, assume caller calls free().*/#define Maxsize 1024// returnSize: 一个指针,用于返回满足条件的路径数量(即最终返回的二维数组的行数)
// returnColumnSizes: 一个指针,用于返回一个数组,该数组存储最终返回的二维数组中每条路径的长度(即二维数组中每列的长度)
// result: 二维整数数组指针,用于存储满足条件的路径数组
// temp: 整数数组,用于临时存储从根节点到当前节点遍历过程中的路径上的节点值
// NodeNum: 用于暂存当前路径上的节点数量
void DFS(struct TreeNode* root, int sum, int* returnSize, int** returnColumnSizes, int** result, int* temp, int NodeNum)
{// 如果当前节点的值等于目标和sum,并且当前节点是叶子节点(即没有左子节点且没有右子节点)if (root->val == sum && root->left == NULL && root->right == NULL){// 将当前节点的值添加到临时路径数组temp中,并更新当前路径上的节点数量NodeNumtemp[NodeNum++] = root->val;// 为当前满足条件的路径分配内存空间,大小为当前路径上的节点数量乘以每个节点值占用的空间result[*returnSize] = malloc(NodeNum * sizeof(int));// 将临时路径数组temp中的值复制到刚分配好的内存空间中,形成一条完整的满足条件的路径for (int i = 0; i < NodeNum; i++){result[*returnSize][i] = temp[i];}// 将当前路径的长度(即NodeNum)存储到用于记录每条路径长度的数组returnColumnSizes中,并更新满足条件的路径数量*returnSize(*returnColumnSizes)[(*returnSize)++]= NodeNum;}else{// 将当前节点的值添加到临时路径数组temp中,并更新当前路径上的节点数量NodeNumtemp[NodeNum++]= root->val;// 如果当前节点的左子节点不为空,递归调用DFS函数继续在左子树中寻找满足条件的路径// 此时目标和更新为sum减去当前节点的值,因为已经将当前节点的值加入到了路径中if (root->left!= NULL) DFS(root->left, sum - root->val, returnSize, returnColumnSizes, result, temp, NodeNum);// 如果当前节点的右子节点不为空,递归调用DFS函数继续在右子树中寻找满足条件的路径// 同样,目标和更新为sum减去当前节点的值if (root->right!= NULL) DFS(root->right, sum - root->val, returnSize, returnColumnSizes, result, temp, NodeNum);}
}// returnSize: 一个指针,用于返回满足条件的路径数量(即最终返回的二维数组的行数)
// returnColumnSizes: 一个指针,用于返回一个数组,该数组存储最终返回的二维数组中每条路径的长度(即二维数组中每列的长度)
int** pathSum(struct TreeNode* root, int sum, int* returnSize, int** returnColumnSizes)
{// 如果根节点为空,说明是空树,直接返回NULL,表示没有找到满足条件的路径if (root == NULL) return NULL;// 定义一个整数数组temp,用于临时存储从根节点到当前节点遍历过程中的路径上的节点值,假设最多能容纳Maxsize个节点值int temp[Maxsize];// 初始化返回的二维整数数组,用于存储满足条件的路径数组,假设最多能容纳Maxsize条路径int** result = malloc(Maxsize * sizeof(int*));// 为用于记录每条路径长度的数组分配内存空间,假设最多能容纳Maxsize条路径的长度信息*returnColumnSizes = malloc(Maxsize * sizeof(int));// 初始化满足条件的路径数量为0*returnSize = 0;// 调用DFS函数开始在二叉树中深度优先搜索,寻找满足条件的路径DFS(root, sum, returnSize, returnColumnSizes, result, temp, 0);// 返回存储满足条件的路径的二维数组,调用者可以通过该数组获取所有满足条件的路径及其长度信息return result;
}

http://www.yayakq.cn/news/560936/

相关文章:

  • 如何零基础做网站wordpress 客户
  • 公司建个网站要多少钱做网站怎么上传
  • 中小企业网站建设 论文南宁学做网站
  • 自己做网站详细步骤别墅装修装饰
  • 做ppt好用的网站怎么在阿里巴巴做网站
  • 中国电力建设企业协会网站出格网站建设公司
  • 江西网站制作公司直播电商的发展趋势
  • 网站建设的初步预算自助建站软件下载
  • 无锡网站建设公司怎么样会员管理系统哪个好用
  • 河北邯郸中考成绩查询网站外贸网站怎么做优化
  • 深圳网站建设知名公司网页设计学习内容
  • 无锡高端网站开发345诛仙网站是谁做的
  • 活动网站怎么建设网络服务器价格
  • 做网站页面多少钱成都推广公司联系电话
  • 淘客网站开发公司企业品牌网站建设注意事项
  • 商务局网站溪江农贸市场建设如何查公司注册信息及法人
  • 推广网站优化怎么做网站首页的布局
  • 网站备案个人使用商城网站建设报价表
  • 网站推广公司电话seo搜索优化工具
  • 阜阳做网站制作网站需要什么语言
  • 四川中天建设有限公司网站建筑工程完工后移交情况说明
  • dedecms5.7装饰网站模板wordpress模块里加载最新文章
  • 会展门户网站源码万网域名注册官网中文域名
  • 网站维护一般需要多久装修网公司装修
  • 山西做网站哪个好米粒网站建设
  • 建设购物网站论文触屏版网站源码
  • 网站后台需求网站的维护怎么做
  • 河南如何做网站三金网手机网站
  • 如何查看网站的更新频率宝安做棋牌网站建设哪家好
  • 太原做企业网站的做链接哪个网站好