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

数据结构与算法编程题20

统计二叉树的叶结点个数。

#define _CRT_SECURE_NO_WARNINGS#include <iostream>
using namespace std;typedef char ElemType;
#define ERROR 0
#define OK 1
typedef struct BiNode
{ElemType data;BiNode* lchild, * rchild;
}BiNode,*BiTree;bool Create_tree(BiTree& T)
{ElemType x = 0;scanf("%c", &x);if (x == '#'){T = NULL;}else{T = (BiTree)malloc(sizeof(BiNode));if (T == NULL){cout << "内存无法分配!!!" << endl;return ERROR;}T->data = x;T->lchild = NULL;T->rchild = NULL;Create_tree(T->lchild);Create_tree(T->rchild);}return OK;
}void PreOrder(BiTree T)
{if (T != NULL){cout << T->data;PreOrder(T->lchild);PreOrder(T->rchild);}
}void InOrder(BiTree T)
{if (T != NULL){InOrder(T->lchild);cout << T->data;InOrder(T->rchild);}
}void PostOrder(BiTree T)
{if (T != NULL){PostOrder(T->lchild);PostOrder(T->rchild);cout << T->data;}
}int leave_node_count(BiTree T)
{if (T == NULL){return 0;}else if (T->lchild == NULL && T->rchild == NULL){return 1;}else{return leave_node_count(T->lchild) + leave_node_count(T->rchild);}
}//ABC##D##E##
//统计二叉树的叶结点个数
int main(void)
{BiTree T = NULL;Create_tree(T);PreOrder(T);cout << endl;InOrder(T);cout << endl;PostOrder(T);cout << endl;cout << "二叉树的叶结点个数:" << leave_node_count(T) << endl;return 0;
}

在这里插入图片描述

相关文章:

数据结构与算法编程题20

统计二叉树的叶结点个数。 #define _CRT_SECURE_NO_WARNINGS#include <iostream> using namespace std;typedef char ElemType; #define ERROR 0 #define OK 1 typedef struct BiNode {ElemType data;BiNode* lchild, * rchild; }BiNode,*BiTree;bool Create_tree(BiTre…...

FreeRTOS源码阅读笔记5--mutex

互斥量是一种特殊的二值信号量&#xff0c;拥有优先级继承的机制&#xff0c;所以适合用在临界资源互斥访问。 5.1创建互斥量xSemaphoreCreateMutex() 5.1.1函数原型 5.1.2函数框架 5.2创建递归互斥量xSemaphoreCreateRecursiveMutex() 5.2.1函数原型 5.2.2函数框架 xSemaph…...

STM32_7(ADC)

一、ADC ADC&#xff08;Analog-Digital Converter&#xff09;模拟-数字转换器ADC可以将引脚上连续变化的模拟电压转换为内存中存储的数字变量&#xff0c;建立模拟电路到数字电路的桥梁12位逐次逼近型ADC&#xff0c;1us转换时间输入电压范围&#xff1a;0~3.3V&#xff0c;…...

Flink实战(11)-Exactly-Once语义之两阶段提交

0 大纲 [Apache Flink]2017年12月发布的1.4.0版本开始&#xff0c;为流计算引入里程碑特性&#xff1a;TwoPhaseCommitSinkFunction。它提取了两阶段提交协议的通用逻辑&#xff0c;使得通过Flink来构建端到端的Exactly-Once程序成为可能。同时支持&#xff1a; 数据源&#…...

日志技术logback

一&#xff0c;日志概括 二&#xff0c;日志技术的特点 三&#xff0c;日志技术的体系 三&#xff0c;入门 四&#xff0c;案例 package XinZheng;import org.slf4j.Logger; import org.slf4j.LoggerFactory;public class Main58 {//1,创建一个Logger日志对象public static fi…...

linux(1)之build构建系统基础(一)

Linux(1)之buildroot构建系统(一) Author&#xff1a;Onceday Date&#xff1a;2023年11月12日 漫漫长路&#xff0c;才刚刚开始… 参考文档&#xff1a; The Yocto ProjectBuildroot - Making Embedded Linux Easy 文章目录 Linux(1)之buildroot构建系统(一)1. 概述1.1 如…...

25 Linux I2C 驱动

一、I2C简介 I2C老朋友了&#xff0c;在单片机里面也学过&#xff0c;现在再复习一下。I2C使用两条线在主控制器和从机之间进行数据通信。一条是 SCL(串行时钟线)&#xff0c;另外一条是 SDA(串行数据线)&#xff0c;这两条数据线需要接上拉电阻&#xff0c;总线空闲的时候 SCL…...

API 设计:使用 Node.js 和 Express.js 的综合教程

API&#xff08;应用程序编程接口&#xff09;设计涉及创建一个高效而强大的接口&#xff0c;允许不同的软件应用程序相互交互。 说明 本教程将指导您使用 Node.js 和 Express.js 作为核心技术来规划、设计和构建 API。但是&#xff0c;这些原则可以应用于任何语言或框架。我们…...

vite和webpack的区别和练习

Vite和Webpack都是现代化的前端构建工具&#xff0c;但它们之间存在一些区别&#xff1a; 构建性能&#xff1a;Vite使用ES Modules提高了构建性能&#xff0c;可以在构建时只构建需要的部分&#xff0c;而Webpack则需要在构建时处理整个应用程序。 开发体验&#xff1a;Vite具…...

Python与设计模式--装饰器模式

6-Python与设计模式–装饰器模式 一、快餐点餐系统 又提到了那个快餐点餐系统&#xff0c;不过今天我们只以其中的一个类作为主角&#xff1a;饮料类。 首先&#xff0c;回忆下饮料类&#xff1a; class Beverage():name ""price 0.0type "BEVERAGE"…...

flutter之graphic图表自定义tooltip

renderer graphic中tooltip的TooltipGuide类提供了renderer方法&#xff0c;接收三个参数Size类型&#xff0c;Offset类型&#xff0c;Map<int, Tuple>类型。可查到的文档是真的少&#xff0c;所以只能在源码中扒拉例子&#xff0c;做符合需求的修改。 官方github示例 …...

逆向扒cocosjs安卓包教程-破解加密的js源码

本文只适用于cocosjs引擎打包的游戏apk,针对此类apk进行源码级别的逆向破解,可直接逐个破解工程内的源码部分,让游戏逻辑大白于你的面前,你可以针对js源码进行二次开发。按照我的教程破解过程中遇到什么问题,欢迎留言。 目录 准备apk包 查找加密key 解密jsc文件 方案1…...

Kafka(一)

一&#xff1a;简介 解决高吞吐量项目的需求 是一款为大数据而生的消息中间件&#xff0c;具有百亿级tps的吞吐量&#xff0c;在数据采集、传输、存储的过程中发挥着作用 二&#xff1a;为什么要使用消息队列 一个普通访问量的接口和一个大并发的接口&#xff0c;它们背后的…...

【Amazon】安装卸载AWS CLI操作流程(Windows 、Linux系统)

AWS 命令行界面&#xff08;AWS CLI&#xff09;是用于管理 AWS 产品的统一工具。只需要下载和配置一个工具&#xff0c;您就可以使用命令行控制多个 AWS 产品并利用脚本来自动执行这些服务。 AWS CLI v2 提供了多项新功能&#xff0c;包括改进的安装程序、新的配置选项&#…...

Django同时连接多种数据库

我的使用场景需要同时连接达梦数据库和MYSQL数据库&#xff0c;有的功能需要查询达梦&#xff0c;有的功能则需要查询MYSQL。 第一步&#xff1a;在 Django 的 settings.py 文件中&#xff0c;配置多个数据库连接。你可以在 DATABASES 字典中添加多个数据库配置。每个数据库配置…...

【链表之练习题】

文章目录 翻转链表找到链表的中间节点返回倒数第k个节点合并两个有序链表判断链表是否回文注意 翻转链表 //反转链表//实质上是把每一个节点头插法,原本第一个节点变成最后一个节点public ListNode reverseList(){//链表为空if (head null){return null;}//链表只有一个节点if…...

情感对话机器人的任务体系

人类在处理对话中的情感时&#xff0c;需要先根据对话场景中的蛛丝马迹判断出对方的情感&#xff0c;继而根据对话的主题等信息思考自身用什么情感进行回复&#xff0c;最后结合推理出的情感形成恰当的回复。受人类处理情感对话的启发&#xff0c;情感对话机器人需要完成以下几…...

【笔记 Pytorch 08】深度学习模板 (未完)

文章目录 一、声明二、工程结构三、文件内容main.pymodel.pydataset.pyutils.py 四、问题汇总 一、声明 非常感谢这些资料的作者&#xff1a; 【参考1】、【PyTorch速成教程 (by Sung Kim)】 二、工程结构 ├── main.py&#xff1a;实现训练 (train) 、验证(validation)和…...

【如何学习Python自动化测试】—— Cookie 处理

前提 网络通信是当今社会最为普及和繁荣的技术之一&#xff0c;其承载了人们生活中瞬息万变的信息传递和交流。而作为网络通信的核心要素&#xff0c;网络协议、socket、cookie和session则是网络通信的灵魂。 一、网络协议 网络协议是计算机和网络设备之间相互通信的规则和标准…...

IOS+Appium+Python自动化全实战教程

由于公司的产品坐落于不同的平台&#xff0c;如ios、mac、Android、windows、web。因此每次有新需求的时候&#xff0c;开发结束后&#xff0c;留给测试的时间也不多。此外&#xff0c;一些新的功能实现&#xff0c;偶尔会影响其他的模块功能正常的使用。 网上的ios自动化方面的…...

别再死记硬背了!用‘预约医生’的例子,5分钟搞懂数据流图里的‘黑洞’、‘白洞’和‘灰洞’

预约医生场景下的数据流图三洞原理&#xff1a;用生活化案例破解系统分析难题 每次打开医院预约系统&#xff0c;看着屏幕上跳转的医生排班表和闪烁的确认按钮&#xff0c;你可能不会想到这背后隐藏着一套精密的数据流动逻辑。就像水管中的水流可能遇到堵塞、泄漏或污染&#x…...

从‘命令未找到’到GPU状态尽在掌握:nvidia-smi环境变量配置全攻略

1. 当nvidia-smi命令罢工时&#xff1a;从报错到定位问题根源 第一次在终端输入nvidia-smi却看到"命令未找到"的提示时&#xff0c;那种感觉就像拿着钥匙却打不开自家大门。作为AI开发者和GPU使用者&#xff0c;我们每天都要和这个强大的监控工具打交道&#xff0c;但…...

PageAdmin平台化:多业务系统动态构建技术

以下是针对“PageAdmin应用系统平台化”的技术实现方案&#xff0c;聚焦于将传统单应用后台管理系统改造为可无限创建业务系统的低代码平台&#xff0c;仅涉及技术架构与实现步骤。 一、平台化核心架构设计 将PageAdmin从“单个后台系统”改造为多业务系统托管平台&#xff0c…...

malloc/free时代终结?2026规范强制引入bounded_alloc与lifetime-aware API——7类传统代码模式已成高危禁区(附自动化检测脚本)

第一章&#xff1a;现代 C 语言内存安全编码规范 2026 对比评测报告随着 CVE-2023–29357 等高危堆溢出漏洞持续暴露传统 C 项目风险&#xff0c;ISO/IEC JTC1 SC22 WG14 于 2025 年底正式发布《C Memory Safety Profile 2026》&#xff08;CMS-2026&#xff09;&#xff0c;作…...

2025最权威的AI辅助写作平台实测分析

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 1. 在内容创作里头&#xff0c;降低人工智能生成内容所占比例&#xff0c;也就是降低AIGC率&…...

React Context 状态共享的性能瓶颈

React Context作为React生态中轻量级的状态共享方案&#xff0c;凭借其简洁的API设计赢得了开发者的青睐。随着应用规模扩大&#xff0c;Context的性能问题逐渐浮出水面&#xff0c;成为制约大型应用流畅性的隐形瓶颈。本文将深入剖析Context状态共享背后的性能陷阱&#xff0c…...

Sigma-Delta ADC选型避坑:为什么ADS124S08的‘低延迟滤波器’才是多通道轮询采集的正确打开方式

Sigma-Delta ADC选型避坑&#xff1a;为什么ADS124S08的‘低延迟滤波器’才是多通道轮询采集的正确打开方式 在工业传感器网络和自动化控制系统中&#xff0c;多通道数据采集的实时性往往比单一通道的极致精度更为关键。许多工程师在选型Sigma-Delta ADC时容易陷入一个典型误区…...

Innovus快捷键实战:如何用键盘流操作替代鼠标点击

Innovus键盘流操作指南&#xff1a;用快捷键提升芯片设计效率 在芯片设计领域&#xff0c;效率往往决定着项目的成败。作为Cadence旗下的物理实现工具&#xff0c;Innovus承载着从布局布线到时序收敛的全流程工作。传统依赖鼠标的操作方式不仅拖慢节奏&#xff0c;还容易导致手…...

Mac效率提升:一键neofetch查系统信息,再也不用点‘关于本机’了(含.zshrc配置详解)

Mac效率革命&#xff1a;用neofetch打造终极系统信息仪表盘 每次需要查看Mac的硬件配置或系统版本时&#xff0c;你是不是还在点击左上角苹果图标→"关于本机"&#xff1f;作为一名整天与终端打交道的开发者&#xff0c;我发现了一个能节省大量时间的秘密武器——neo…...

GB15084-2027实施在即,手把手教你解读CMS电子后视镜的法规合规要点

GB15084-2027法规深度解析&#xff1a;CMS电子后视镜合规实战指南 当传统光学镜片遇上数字成像技术&#xff0c;汽车间接视野系统正经历着自后视镜发明以来最彻底的变革。GB15084-2027&#xff08;注&#xff1a;应为GB15084-2022&#xff0c;原文标题有误&#xff09;的实施不…...