备战蓝桥杯Day19 - 堆排序基础知识

一、每日一题 - 填充

详细题解

python 复制代码
s = input()  # 输入字符串
n = len(s)  # 定义字符的长度
judge = ["00", "11", "0?", "1?", "?0", "?1", "??"]
# 把所有的情况一一列举出来
count = 0  # 设置计数器
i = 1  # 设置循环条件索引值
while i < n:
    if s[i-1:i+1] in judge:  # 在循环中将字符串遍历进行判断
        count += 1  # 如果符合计数器 + 1
        i += 2  # 并将索引值向后移动2个
    else:
        i += 1 # 不符合条件索引值向后移1个

print(count)  # 最后打印出结果

我觉得最难的在于不纠结?到底是0还是1,而是直接把他看成数字去跟已知情况进行判断。我一直在纠结?到底应该什么时候是1,什么时候是0,把自己的思路的限制住了。

二、堆排序

预备基础知识 - 树

一些基本知识:

根节点:每棵树最上面的单独的一个节点,如上图A为根节点。

叶子节点:每棵树中最末梢的,不再有分支的节点。如上图B,C,H,I,P,Q,K,L,M,N为叶子节点。

树的深度(高度):层数是几,深度(高度)是几。如上图树的深度(高度)是4,因为有4层。

节点的度:某个分叉的节点分了几个叉,节点的度就是几。如上图E的度为2,F的度为3.

树的度: 节点的度中最大的数,就是树的度。如上图节点的度最大为A分了6个叉,所以树的度为6

孩子节点/父节点:挂在某个节点下面,称为这个节点的孩子节点,某个节点称为父节点。如上图中E是父节点,I,J是孩子节点。

子树:在树中单独拎出来一些节点还能组成树的,称为这棵树的子树。如上图中E,F,G单独拎出来后还是一棵树,故能称为是A这棵树的子树。

这些都是按照我理解的概念写出来的,可能不完善也不是很清楚,最好还是参考课本上的定义概念。

二叉树

满二叉树、完全二叉树

完全二叉树:最下一层可以不满,但节点序号必须按照从左到右排序的方式进行排列

二叉树的存储方式

因为堆排序要用到二叉树的存储方式,所以要了解一下

在堆排序中我们使用顺序存储方式,那么就是把数字放到列表中,在下图中找到父节点与左孩子和右孩子节点之间的数字关系,以方便我们去寻找数据。

堆排序 - 什么是堆

堆的向下调整

节点的左右子树都是堆,但自身不是堆,可以通过一次次的向下调整来将其变成一个堆。

堆排序的过程

ok代码实现问题明日再学习。

三、学习碎碎念

慢慢开始上难度了,今天上算法课回答问题了,根据之前自己的冒泡排序的笔记,果然是一份耕耘一份收获啊。也想对自己说别太浮躁,别太着急,慢慢来,一步一个脚印,踏踏实实的,努力的去迎接自己的未来。

相关推荐
炒空心菜菜6 分钟前
SparkSQL 连接 MySQL 并添加新数据:实战指南
大数据·开发语言·数据库·后端·mysql·spark
程序媛小盐12 分钟前
贪心算法:最小生成树
算法·贪心算法·图论
张小九9912 分钟前
PyTorch的dataloader制作自定义数据集
人工智能·pytorch·python
Panesle14 分钟前
分布式异步强化学习框架训练32B大模型:INTELLECT-2
人工智能·分布式·深度学习·算法·大模型
zstar-_22 分钟前
FreeTex v0.2.0:功能升级/支持Mac
人工智能·python·macos·llm
c6lala24 分钟前
数据结构day1
数据结构
苏生要努力28 分钟前
第九届御网杯网络安全大赛初赛WP
linux·python·网络安全
多多*30 分钟前
算法竞赛相关 Java 二分模版
java·开发语言·数据结构·数据库·sql·算法·oracle
逐光沧海31 分钟前
数据结构基础--蓝桥杯备考
数据结构·c++·算法·蓝桥杯
Kidddddult32 分钟前
力扣刷题Day 48:盛最多水的容器(283)
算法·leetcode·力扣