悄悄话花费的时间(C语言)

news2024/12/23 10:03:14

题目描述

给定一个二叉树,每个节点上站着一个人,节点数字表示父节点到该节点传递悄悄话需要花费的时间。
初始时,根节点所在位置的人有一个悄悄话想要传递给其他人,求二叉树所有节点上的人都接收到悄悄话花费的时间。

输入描述

给定二叉树

0 9 20 -1 -1 15 7 -1 -1 -1 -1 3 2

在这里插入图片描述

注:-1 表示空节点

输出描述

返回所有节点都接收到悄悄话花费的时间 38

示例一

输入
0 9 20 -1 -1 15 7 -1 -1 -1 -1 3 2
输出
38

思路

解题思路:

  1. 构建二叉树:首先,根据题目给出的输入数组(层序遍历顺序),通过递归函数 build 构建一棵完全二叉树。在函数中,当遇到非空节点时(数组值不为-1),创建一个新节点并将其值设置为数组中的当前元素,然后递归地构建其左、右子节点。

  2. 计算传递时间总和:定义一个递归函数 timeSum 来计算以给定节点为根的二叉树中所有节点接收悄悄话所需的时间总和。

    • 当遍历到空节点时,返回0,表示没有额外的传递时间;
    • 对于非空节点,首先递归计算左子树和右子树的最大传递时间;
    • 将当前节点的值与左右子树中的较大传递时间相加,得到从当前节点开始向下传递悄悄话所需的时间;
    • 最终,根节点下的时间总和即为整个二叉树所有节点接收到悄悄话的总时间。
  3. 读取输入:在 main 函数中,读取输入数据,将每个节点值存入数组 nums 中。

  4. 处理输入并计算结果:利用 build 函数根据输入数组构建二叉树,然后调用 timeSum 函数计算所有节点接收悄悄话所需的时间总和,并输出结果。

代码

无注释版本

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef struct TreeNode {
    int value;
    struct TreeNode *left;
    struct TreeNode *right;
} TreeNode;

TreeNode *build(int nums[], int index, int size) {
    if (index < size && nums[index] != -1) {
        TreeNode *root = (TreeNode *)malloc(sizeof(TreeNode));
        root->value = nums[index];
        root->left = build(nums, 2 * index + 1, size);
        root->right = build(nums, 2 * index + 2, size);
        return root;
    }
    return NULL;
}

int timeSum(TreeNode *root) {
    if (root == NULL) {
        return 0;
    }
    int leftSum = timeSum(root->left);
    int rightSum = timeSum(root->right);
    return root->value + (leftSum > rightSum ? leftSum : rightSum);
}
int main() {
    int nums[100];
    int size = 0;

    while (scanf("%d", &nums[size]) != EOF) {
        size++;
    }
    TreeNode *root = build(nums, 0, size);
    int res = timeSum(root);
    printf("%d\n", res);
    return 0;
}

有注释版本

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

// 定义二叉树节点结构体,包含值、左子节点和右子节点
typedef struct TreeNode {
    int value; // 节点值表示从父节点到该节点传递悄悄话需要的时间
    struct TreeNode *left;  // 左子节点指针
    struct TreeNode *right; // 右子节点指针
} TreeNode;

// 函数:build
// 功能:根据输入数组构建一棵完全二叉树
// 参数:
//   nums[] - 输入整数数组,按照二叉树层序遍历顺序存储节点值
//   index - 当前处理的数组下标
//   size - 数组大小
// 返回值:
//   构建好的二叉树根节点指针
TreeNode *build(int nums[], int index, int size) {
    // 如果当前下标有效且不为-1(非空节点)
    if (index < size && nums[index] != -1) {
        TreeNode *root =
            (TreeNode *)malloc(sizeof(TreeNode)); // 为新节点分配内存
        root->value = nums[index];                // 设置节点值
        root->left = build(nums, 2 * index + 1, size);  // 创建左子节点
        root->right = build(nums, 2 * index + 2, size); // 创建右子节点
        return root;
    }
    return NULL; // 如果遇到空节点,则返回NULL
}

// 函数:timeSum
// 功能:计算以给定节点为根的二叉树中所有节点接收悄悄话所需的时间总和
// 参数:
//   root - 二叉树根节点指针
// 返回值:
//   所有节点接收到悄悄话花费的总时间
int timeSum(TreeNode *root) {
    if (root == NULL) { // 如果为空节点,则返回0(没有传递时间)
        return 0;
    }

    // 计算左右子树中的最大传递时间
    int leftSum = timeSum(root->left);
    int rightSum = timeSum(root->right);

    // 返回当前节点的值加上左右子树中较大传递时间
    return root->value + (leftSum > rightSum ? leftSum : rightSum);
}

int main() {
    int nums[100];
    int size = 0;

    // 读取输入直到文件结束,并将节点值存入数组
    while (scanf("%d", &nums[size]) != EOF) {
        size++;
    }

    // 根据输入数组构建二叉树
    TreeNode *root = build(nums, 0, size);

    // 计算所有节点接收到悄悄话的总时间
    int res = timeSum(root);
    printf("%d\n", res);

    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1466011.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

企业统一身份中台,如何比传统单点登录SSO做得更好?

传统的单点登录SSO方案往往仅解决以下问题&#xff1a;多应用系统入口不统一&#xff0c;导致员工需要切换多个登录地址&#xff0c;重复多次登录&#xff0c;极大影响业务访问效率及员工登录体验。随着IT基础设施的增多&#xff0c;企业对全场景&#xff08;如网络、VPN、云桌…

Jmeter基础(2) 目录介绍

目录 Jmeter目录介绍bin目录docsextrasliblicensesprintable_docs Jmeter目录介绍 在学习Jmeter之前&#xff0c;需要先对工具的目录有些了解&#xff0c;也会方便后续的学习 bin目录 examplesCSV目录中有CSV样例jmeter.batwindow 启动文件jmeter.shMac/linux的启动文件jmete…

flink内存管理,设置思路,oom问题,一文全

flink内存管理 1 内存分配1.1 JVM 进程总内存&#xff08;Total Process Memory&#xff09;1.2 Flink 总内存&#xff08;Total Flink Memory&#xff09;1.3 JVM 堆外内存&#xff08;JVM Off-Heap Memory&#xff09;1.4 JVM 堆内存&#xff08;JVM Heap Memory&#xff09;…

如何在Pycharm中导入第三方库(以pyecharts为例子)

打开Pycharm 点击右上角文件->设置->项目->pythonProject&#xff08;Python解释器&#xff09; 点击下图号 下一步&#xff1a;在搜索栏中直接搜索第三方包pyecharts并安装即可 以上便为使用Pycharm安装第三方库的全过程。 温馨小提示&#xff0c;如果大家在Pychar…

研学活动报名平台系统功能清单

中小学生社会实践活动、研学旅行等素质教育活动报名与管理平台&#xff0c;功能包含&#xff1a;活动分类&#xff0c;活动管理&#xff0c;在线报名缴费&#xff0c;扫码核销&#xff0c;会员特权体系&#xff0c;在线商城&#xff0c;研学互动。系统支持入驻老师自行创建研学…

代码随想录算法训练营第二十六天|39. 组合总和、40.组合总和II、131.分割回文串

39. 组合总和 刷题https://leetcode.cn/problems/combination-sum/description/文章讲解https://programmercarl.com/0039.%E7%BB%84%E5%90%88%E6%80%BB%E5%92%8C.html视频讲解https://www.bilibili.com/video/BV1KT4y1M7HJ/?vd_sourceaf4853e80f89e28094a5fe1e220d9062 回溯…

【数据分享】2014-2024年全国监测站点的逐年空气质量数据(15个指标\免费获取)

空气质量的好坏反映了空气的污染程度&#xff0c;在各项涉及城市环境的研究中&#xff0c;空气质量都是一个十分重要的指标。空气质量是依据空气中污染物浓度的高低来判断的。 我们发现学者王晓磊在自己的主页里面分享了2014年5月以来的全国范围的到站点的逐时空气质量数据&am…

【Python笔记-设计模式】组合模式

一、说明 组合模式是一种结构型设计模式&#xff0c; 你可以使用它将对象组合成树状结构&#xff0c; 并且能像使用独立对象一样使用它们。 (一) 解决问题 处理树形结构&#xff1a;可以很好地处理树形结构的数据&#xff0c;使得用户可以统一对待单个对象和对象组合。统一接…

【LeetCode每日一题】 单调栈的案例 42. 接雨水

这道题是困难&#xff0c;但是可以使用单调栈&#xff0c;非常简洁通俗。 关于单调栈可以参考单调栈总结以及Leetcode案例解读与复盘 42. 接雨水 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图&#xff0c;计算按此排列的柱子&#xff0c;下雨之后能接多少雨水。 示例 …

2 物理层(五):传输介质

目录 1 传输介质1.1 有线传输媒体1、双绞线2、同轴电缆3、光纤 1.2 无线传输媒体1、无线电波段分配2、微波通信3、卫星通信4、红外通信和激光通信 1 传输介质 物理层传输的二进制比特流需要在传输介质上实现。传输介质是数据传输的物理通道&#xff0c;它还能连接主机和各种网…

【JAVA】中的静态代理、动态代理以及CGLIB动态代理

目录 1.静态代理 2.动态代理 3.cglib代理 代理模式是java中最常用的设计模式之一&#xff0c;尤其是在spring框架中广泛应用。对于java的代理模式&#xff0c;一般可分为&#xff1a;静态代理、动态代理、以及CGLIB实现动态代理。 对于上述三种代理模式&#xff0c;分别进行…

Kubernetes 二进制部署 《easzlab / kubeasz项目部署》(一)

Kubernetes 二进制部署 - easzlab / kubeasz项目部署 1. 准备工作1.1 设置防火墙1.2 设置SeLinux1.3 设置时区及时间同步1.4 配置域名解析1.5 确认SSH开启1.6 IP转发1.7 安装docker1.8 关闭swap 2. 服务器规划2.1 基本架构图2.2 官方建议2.3 实践服务器规划 3. 服务器配置3.1 配…

基于MPPT最大功率跟踪算法的涡轮机控制系统simulink建模与仿真

目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 5.完整工程文件 1.课题概述 基于MPPT最大功率跟踪算法的涡轮机控制系统simulink建模与仿真.mppt采用爬山法实现&#xff0c;仿真输出MPPT控制效果&#xff0c;功率&#xff0c;转速等。 2.系统仿真结果 …

SQL注入漏洞解析--less-2

首先我们进入第二关 思路&#xff1a; 1.先判断是什么类型的注入 2.根据类型我们在找注入点 步骤&#xff1a; 1.提示我们输入id数字&#xff0c;那我们先输入1猜一下 2.这里正常回显&#xff0c;当我们后边加上时可以看到报错&#xff0c;且报错信息看不到数字&#xff0…

Go 中如何高效遍历目录?探索几种方法

嗨&#xff0c;大家好&#xff01;我是波罗学。本文是系列文章 Go 技巧第十八篇&#xff0c;系列文章查看&#xff1a;Go 语言技巧。 目录遍历是一个很常见的操作&#xff0c;它的使用场景有如文件目录查看&#xff08;最典型的应用如 ls 命令&#xff09;、文件系统清理、日志…

知识积累(二):损失函数正则化与权重衰减

文章目录 1. 欧氏距离与L2范数1.1 常用的相似性度量 2. 什么是正则化&#xff1f;参考资料 本文只介绍 L2 正则化。 1. 欧氏距离与L2范数 欧氏距离也就是L2范数 1.1 常用的相似性度量 1&#xff09;点积 2&#xff09;余弦相似度 3&#xff09;L1和L2 2. 什么是正则化&…

游戏史上五个定价最高的量产型游戏机

你买过微软和索尼的下一代游戏机PS5和XBOX吗&#xff1f; PS5光驱版售价499美元&#xff0c;无光驱版售价399美元&#xff0c;高端版售价499美元&#xff0c;入门版售价低至299美元。 对于这样的定价&#xff0c;你觉得贵还是便宜呢&#xff1f; 为什么不让我们垂直比较整个游戏…

前端数据可视化:ECharts使用

可视化介绍 ​  ​  应对现在数据可视化的趋势&#xff0c;越来越多企业需要在很多场景(营销数据&#xff0c;生产数据&#xff0c;用户数据)下使用&#xff0c;可视化图表来展示体现数据&#xff0c;让数据更加直观&#xff0c;数据特点更加突出。   ​  数据可视化主要目…

【论文精读】IBOT

摘要 掩码语言建模(MLM)是一种流行的语言模型预训练范式&#xff0c;在nlp领域取得了巨大的成功。然而&#xff0c;它对视觉Transformer (ViT)的潜力尚未得到充分开发。为在视觉领域延续MLM的成功&#xff0c;故而探索掩码图像建模(MIM)&#xff0c;以训练更好的视觉transforme…

ico图片怎么制作(图片怎么变成ico格式)

ico图片一般命名为favicon.ico&#xff0c;主要用于作为缩略的网站标志&#xff0c;显示在浏览器的地址栏或者在标签中&#xff0c;一般用网站logo来制作。那么ico图片怎么制作&#xff1f;Logo图片怎么变成ico格式&#xff1f;下面boke112百科就跟大家说一说ico图片制作步骤&a…