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

针对考研的C语言学习(2014二叉树大题代码实战)

题目描述

解析

 1.递归思想遍历节点,若是叶子结点就累加计算的wpl,反之继续遍历

 

 2.代码如下

//树
typedef struct trees {ElemType data;struct trees* lc;struct trees* rc;
}treeNode, * Tree;

3.算法设计

//deep路径长度也叫做深度,0开始
void getWPL(Tree& t, int deep,int &sum)
{//判断左子树if (t->lc){getWPL(t->lc, deep + 1, sum);}if (t->rc){getWPL(t->rc, deep + 1, sum);}if (!t->lc && !t->rc){//叶子结点sum += deep * t->data;return;}
}

 【注】递归一定要有终止条件,否则会死循环。

可运行代码

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
typedef char ElemType;//树
typedef struct trees {ElemType data;struct trees* lc;struct trees* rc;
}treeNode, * Tree;//链表
typedef struct Links {Tree tree;struct Links* next;
}LNode, * LinkList;//队列
typedef struct {LinkList front;LinkList rear;
}LinkQue;void init_que(LinkQue& q)
{q.front = q.rear = (LinkList)calloc(1, sizeof(LNode));q.front = q.rear;
}bool isEmpty(LinkQue& q)
{return q.front == q.rear;
}//入队
void push_que(LinkQue& q, Tree tree)
{//新建链表节点LinkList newList = (LinkList)calloc(1, sizeof(LNode));newList->next = NULL;newList->tree = tree;q.rear->next = newList;q.rear = q.rear->next;
}
bool pop_que(LinkQue& q, Tree& tree)
{if (isEmpty(q)){return false;}LinkList del = q.front->next;//头结点不存数据,第一个节点才是真的数据起始位置q.front->next = del->next;//断链tree = del->tree;if (q.rear == del)//只剩下尾节点的数据{q.rear = q.front;//置空}free(del);return true;
}void build_tree(Tree& tree)
{LinkQue q;init_que(q);LinkList cur = NULL;ElemType data;while (scanf("%c", &data) && data != '\n'){Tree newTree = (Tree)calloc(1, sizeof(treeNode));//申请新的树的节点newTree->data = data;if (tree == NULL){tree = newTree;push_que(q, tree);//入队cur = q.rear;}else{if (cur->tree->lc == NULL){cur->tree->lc = newTree;push_que(q, newTree);}else{cur->tree->rc = newTree;push_que(q, newTree);//改变当前父亲节点cur = cur->next;}}}
}void getWPL(Tree& t, int deep,int &sum)
{//判断左子树if (t->lc){getWPL(t->lc, deep + 1, sum);}if (t->rc){getWPL(t->rc, deep + 1, sum);}if (!t->lc && !t->rc){//叶子结点sum += deep * t->data;return;}
}int main()
{Tree tree = NULL;build_tree(tree);int sum = 0;getWPL(tree, 0, sum);printf("%d\n", sum);return 0;
}

代码运行结果

http://www.lryc.cn/news/468517.html

相关文章:

  • webpack面试笔记(一)
  • 雷池社区版有多个防护站点监听在同一个端口上,匹配顺序是怎么样的
  • 【小白学机器学习15】 概率论的世界观
  • 合成数据用于大模型训练的3点理解
  • Safari 中 filter: blur() 高斯模糊引发的性能问题及解决方案
  • 浏览器实时更新esp32-c3 Supermini http server 数据
  • 【亚马逊云】基于 Amazon EKS 搭建开源向量数据库 Milvus
  • pytorch安装GPU版本,指定设备
  • 草地杂草数据集野外草地数据集田间野草数据集YOLO格式VOC格式目标检测计算机视觉数据集
  • 顺序表排序相关算法题|负数移到正数前面|奇数移到偶数前面|小于x的数移到大于x的数前面|快排思想(C)
  • 【小白学机器学习20】单变量分析 / 0因子分析 (只分析1个变量本身的数据)
  • [软件工程]—桥接(Brige)模式与伪码推导
  • TensorFlow面试整理-TensorFlow 结构与组件
  • linux下gpio模拟spi三线时序
  • makesense导出的压缩包是空的
  • Spring Boot框架下的中小企业设备维护系统
  • 处理文件上传和进度条的显示(进度条随文件上传进度值变化)
  • 【套题】大沥2019年真题——第5题
  • 上传Gitee仓库流程图
  • 二叉树相关OJ题 — 第一弹
  • 【学习笔记】RFID
  • 自动化部署-01-jenkins安装
  • AI工具大爆发,建议每个都使用收藏
  • Mybatis之参数处理
  • windows内核探索--打印windows的GDT表(全局描述符表)
  • 【ChatGPT】让ChatGPT帮助进行头脑风暴与创意生成
  • 大数据处理随堂测试
  • 2024最新pycharm安装教程及基本使用(超详细,新手小白必看)
  • 三国杀钓鱼自动化
  • 在pycharm中使用sqllite