代码随想录_刷题记录_第四次

二叉树 — 理论基础

种类:

  • 满二叉树(所有层的节点都是满的,k:深度 节点数量:2^k - 1)
  • 完全二叉树(除了最后一层,其余层全满,并且最后一层从左到右连续)
  • 二叉搜索树(对于每一个父节点来说,左子树的所有节点都小于父节点,右子树的所有节点都大于父节点 时间复杂度 : log(n) )
  • 平衡二叉搜索树(左子树和右子树的高度差不能大于1 时间复杂度:log(n)

存储方式:

  • 链式存储(左指针、右指针)
  • 线式存储(数组 父节点 i,左子节点 2i + 1,右子节点 2i + 2)

遍历方式:

  • 深度优先搜索:递归方式实现(前序、中序、后序)、迭代法(使用栈)
  • 广度优先搜索:一层一层的去遍历(迭代法,使用队列)(层序遍历)

前序:中左右 中序:左中右 后序:左右中

定义方法:

struct TreeNode{int value;TreeNode* left;TreeNode* right;TreeNode(int val) : value(val) left(NULL) right(NULL) {}
}

**二叉树节点的深度:**从根节点到该节点的最长简单路径边的条数(前序递归求深度)

**二叉树节点的高度:**从该节点到叶子节点(左右子节点都为空)的最长简单路径边的条数(后序递归求高度)

前序遍历求深度,后序遍历求高度

二叉树 — 递归遍历

递归遍历的三步骤:

  1. 确定递归函数的参数和返回值
  2. 确定终止条件
  3. 确定单层递归的逻辑

前序遍历

题目链接:144. 二叉树的前序遍历 - 力扣(LeetCode)

**题目要求:**给你二叉树的根节点 root ,返回它节点值的 前序 遍历。

示例 :

**输入:**root = [1,2,3,4,5,null,8,null,null,6,7,9]

输出:[1,2,4,5,6,7,3,8,9]

解释:

img

思路:

  1. 确定参数(根节点、vec数组)和返回值(void)

    void traversal(TreeNode* cur, vector<int>& vec)
    
  2. 确定终止条件(深度优先搜索,cur == NULL return)

    if (cur == NULL) return;
    
  3. 确定单层递归的逻辑

    vec.push_back(cur->val);    // 中
    traversal(cur->left, vec);  // 左
    traversal(cur->right, vec); // 右
    

解法:

  • C++
class Solution {
public:void traversal(TreeNode* cur, vector<int>& vec){if(cur == NULL) return;vec.push_back(cur->val);      // 中traversal(cur->left, vec);    // 左traversal(cur->right, vec);   // 右}vector<int> preorderTraversal(TreeNode* root) {vector<int> result;traversal(root, result);   // 传入根节点和存放结果的数组return result;}
};

中序遍历

题目链接:94. 二叉树的中序遍历 - 力扣(LeetCode)

  • C++
class Solution {
public:void traversal(TreeNode* cur, vector<int>& vec){if(cur == NULL) return;traversal(cur->left, vec);    // 左vec.push_back(cur->val);      // 中traversal(cur->right, vec);   // 右}vector<int> inorderTraversal(TreeNode* root) {vector<int> result;traversal(root, result);   // 传入根节点和存放结果的数组return result;}
};

后序遍历

题目链接:145. 二叉树的后序遍历 - 力扣(LeetCode)

  • C++
class Solution {
public:void traversal(TreeNode* cur, vector<int>& vec){if(cur == NULL) return;traversal(cur->left, vec);    // 左traversal(cur->right, vec);   // 右vec.push_back(cur->val);      // 中}vector<int> postorderTraversal(TreeNode* root) {vector<int> result;traversal(root, result);   // 传入根节点和存放结果的数组return result;}
};

二叉树 — 迭代遍历

**递归的实现:**每一次递归调用都会把函数的局部变量、参数值和返回地址等压入调用栈中,然后递归返回的时候,从栈顶弹出上一次递归的各项参数,所以这就是递归为什么可以返回上一层位置的原因

所以,我们使用栈也可以实现二叉树的前中后序遍历

前序遍历

**思路:**用栈存放节点,用数组存放结果

先将根节点放入栈中,进入循环直到栈为空,取出栈顶结点作为中间节点(中左右),放入这个节点的右子节点,再放入这个节点的左子节点(取出时是先取左子节点)(如果为空则不放入)

解法:

  • C++
class Solution {
public:vector<int> preorderTraversal(TreeNode* root) {vector<int> result;stack<TreeNode*> st;if(root == NULL) return result;st.push(root);   // 先将根节点放入栈中while(!st.empty()){TreeNode* cur = st.top();   // 取出栈顶结点作为这次的中间节点st.pop();           result.push_back(cur->val);if(cur->right) st.push(cur->right);   // 向栈中放入右子节点,如果为空则不放入if(cur->left)  st.push(cur->left);    // 向栈中放入左子节点} return result;}
};

后序遍历

**思路:**跟前序遍历相同,只不过调转了左右子节点入栈的顺序,此时输出的结果为 中右左,所以需要调换顺序输出 左右中

解法:

  • C++
class Solution {
public:vector<int> postorderTraversal(TreeNode* root) {vector<int> result;stack<TreeNode*> st;if(root == NULL) return result;st.push(root);   // 先将根节点放入栈中while(!st.empty()){TreeNode* cur = st.top();   // 取出栈顶结点作为这次的中间节点st.pop();result.push_back(cur->val);if(cur->left)  st.push(cur->left);    // 向栈中放入左子节点if(cur->right) st.push(cur->right);   // 向栈中放入右子节点,如果为空则不放入}   reverse(result.begin(), result.end());    // 中右左 -> 左右中return result;}
};

中序遍历

思路:

写法与前序遍历、后序遍历不同,因为前序遍历和后序遍历的顺序是中左右、中右左(最后反转),要访问的元素和要处理的元素顺序是一致的,但是中序遍历 左中右 处理顺序和访问顺序是不一致的

所以,在使用迭代法写中序遍历的时候,就需要借用指针的遍历来帮助访问节点,栈则用来处理节点上的元素

解法:

  • C++
class Solution {
public:vector<int> inorderTraversal(TreeNode* root) {vector<int> result;stack<TreeNode*> st;TreeNode* cur = root;while(cur || !st.empty()){if(cur){   // 向该子节点的左子节点一直遍历,直到为空st.push(cur);   // 将所有节点放入栈中cur = cur->left;}else{   // 若已经遍历到底cur = st.top();   // 取出栈顶元素(最左子节点)st.pop();result.push_back(cur->val);   // 放入左子节点cur = cur->right;   // 取出右子节点重复操作}}return result;}
};

二叉树 — 层序遍历

层序遍历 I

题目链接:102. 二叉树的层序遍历 - 力扣(LeetCode)

**题目要求:**给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。

示例1:

image-20240924171110192

输入:root = [3,9,20,null,null,15,7]
输出:[[3],[9,20],[15,7]]

示例 2:

输入:root = [1]
输出:[[1]]

示例 3:

输入:root = []
输出:[]

**思路:**借助队列保存每一层中遍历的元素

解法:

  • C++
class Solution {
public:vector<vector<int>> levelOrder(TreeNode* root) {queue<TreeNode*> que;vector<vector<int>> result;if(root == NULL) return result;que.push(root);while(!que.empty()){vector<int> vec;   // 保存每一层的节点数据int size = que.size();   // 记录每一层节点的数量for(int i = 0; i < size; i++){TreeNode* cur = que.front();   // 访问队列的头部元素que.pop();vec.push_back(cur->val);if(cur->left)  que.push(cur->left);if(cur->right) que.push(cur->right);}result.push_back(vec);}return result;}
};

二叉树的最大深度

题目链接:104. 二叉树的最大深度 - 力扣(LeetCode)

题目要求:

给定一个二叉树 root ,返回其最大深度。

二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。

**思路:**仍然是使用队列保存每一层的数据,不过在进行层切换时要计数

解法:

  • C++
class Solution {
public:int maxDepth(TreeNode* root) {queue<TreeNode*> que;int result = 0;if(!root) return result;que.push(root);while(!que.empty()){result++;int size = que.size();while(size--){TreeNode* cur = que.front();que.pop();if(cur->left)  que.push(cur->left);if(cur->right) que.push(cur->right);}}return result;}
};

二叉树的最小深度

题目链接:111. 二叉树的最小深度 - 力扣(LeetCode)

题目要求:

给定一个二叉树,找出其最小深度。

最小深度是从根节点到最近叶子节点(左右子节点都为 NULL 的节点)的最短路径上的节点数量。

**说明:**叶子节点是指没有子节点的节点。

示例 1:

输入:root = [3,9,20,null,null,15,7]
输出:2

示例 2:

输入:root = [2,null,3,null,4,null,5,null,6]
输出:5

解法:

  • C++
class Solution {
public:int minDepth(TreeNode* root) {queue<TreeNode*> que;int result = 0;if(!root) return result;que.push(root);while(!que.empty()){result++;int size = que.size();while(size--){TreeNode* cur = que.front();que.pop();if(cur->left)  que.push(cur->left);if(cur->right) que.push(cur->right);if(!cur->left && !cur->right) // 当左子节点与右子节点都为空时就代表最小深度return result;}}return result;}
};

二叉树 — 翻转二叉树

题目链接:226. 翻转二叉树 - 力扣(LeetCode)

**题目要求:**给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。

示例 1:

img

输入:root = [4,2,7,1,3,6,9]
输出:[4,7,2,9,6,3,1]

示例 2:

img

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

示例 3:

输入:root = []
输出:[]

思路:

只要将每一个节点的左右子节点翻转一下,就可以达到整体翻转的效果

使用 前序/后续 对二叉树进行递归遍历,中序(会将某些节点的左右子节点翻转两次)

1、递归函数的参数(TreeNode *),返回值(TreeNode *)

TreeNode* invertTree(TreeNode* cur)

2、终止条件(root == NULL)

if (root == NULL) return NULL;

3、单层递归逻辑(交换传入节点的左右子节点)

swap(root->left, root->right);   // 交换两个变量的值
invertTree(root->left);
invertTree(root->right);

解法:

  • C++(前序遍历 递归)
class Solution {
public:TreeNode* invertTree(TreeNode* root) {if(!root) return NULL;swap(root->left,root->right); // 中invertTree(root->left);       // 左invertTree(root->right);      // 右return root;}
};
  • C++(后序遍历 递归)
class Solution {
public:TreeNode* invertTree(TreeNode* root) {if(!root) return NULL;invertTree(root->left);       // 左invertTree(root->right);      // 右swap(root->left,root->right); // 中return root;}
};

二叉树 — 对称二叉树

题目链接:101. 对称二叉树 - 力扣(LeetCode)

**题目要求:**给你一个二叉树的根节点 root , 检查它是否轴对称。

示例 1:

img

输入:root = [1,2,2,3,4,4,3]
输出:true

示例 2:

img

输入:root = [1,2,2,null,3,null,3]
输出:false

思路:

判断是否为对称二叉树,其实就是判断左子树和右子树是否可以相互翻转,真正要比较的是两个树(根节点的左右子树)(比较两个子树的里侧和外侧元素是否相等),所以在递归遍历的过程中,也是要同时遍历两棵树

只能使用后续遍历(左右中)

正因为要遍历两棵树而且要比较内测和外侧节点,所以准确来说是一个树的遍历顺序是左右中,一个树的遍历顺序是右左中

1、递归函数的参数(TreeNode* left TreeNode* right),返回值(bool)

bool compare(TreeNode* left, TreeNode* right)

2、确定终止条件

if (left == NULL && right != NULL) return false;
else if (left != NULL && right == NULL) return false;
else if (left == NULL && right == NULL) return true;
else if (left->val != right->val) return false; 

3、确定单层递归的逻辑

bool outside = compare(left->left, right->right);   // 左子树:左、 右子树:右
bool inside = compare(left->right, right->left);    // 左子树:右、 右子树:左
bool isSame = outside && inside;                    // 左子树:中、 右子树:中(逻辑处理)
return isSame;

解法:

  • C++
class Solution {
public:bool compare(TreeNode* left, TreeNode* right){if(left == NULL && right == NULL) return true;else if(left != NULL && right == NULL) return false;else if(left == NULL && right != NULL) return false;else if(left->val != right->val) return false; // 这个条件已经比较了每一个节点的值bool cmp_left  = compare(left->left, right->right);bool cmp_right = compare(left->right, right->left);return cmp_left && cmp_right;}bool isSymmetric(TreeNode* root) {if(root == NULL) return true;return compare(root->left, root->right);}
};

二叉树 — 二叉树的最大深度

题目链接:104. 二叉树的最大深度 - 力扣(LeetCode)

**思路:**这里使用递归法,也可以使用层序遍历

使用前序递归求深度,使用后序递归求高度,而根节点的高度就是整个二叉树的深度,所以这道题实际上是使用后续递归求根节点的高度

1、确定递归的参数和返回值

int maxDepth(TreeNode* node)

2、确定终止条件(如果为空节点,就返回0,表示高度为0)

if (node == NULL) return 0;

3、单层递归的逻辑:先求它的左子树的深度,再求右子树的深度,最后取左右深度最大的数值 再+1 (加1是因为算上当前中间节点)就是目前节点为根节点的树的深度

int leftdepth = getdepth(node->left);       // 左
int rightdepth = getdepth(node->right);     // 右
int depth = 1 + max(leftdepth, rightdepth); // 中
return depth;

解法:

  • C++
class Solution {
public:int maxDepth(TreeNode* root) {if (root == NULL) return 0;int leftdepth  = maxDepth(root->left);       // 左int rightdepth = maxDepth(root->right);      // 右int depth = 1 + max(leftdepth, rightdepth);  // 中return depth;}
};

二叉树 — 二叉树的最小深度

题目链接:111. 二叉树的最小深度 - 力扣(LeetCode)

**思路:**依旧是前序递归遍历求深度,后序递归遍历求高度

这里使用后序遍历求最小深度

最小深度是从根节点到最近叶子节点(左右子节点都为空)的最短路径上的节点数量。

1、确定递归函数的参数和返回值

int minDepth(TreeNode* node)

2、确定终止条件(遇到空节点,返回 0)

if(node == NULL) return 0;

3、确定单层递归的逻辑

int leftDepth = getDepth(node->left);
int rightDepth = getDepth(node->right);
// 当只有一个子节点时,就顺着这个子节点继续往下查
if(node->left == NULL && node->right != NULL){return 1 + rightDepth;
}
if(node->left != NULL && node->right == NULL){return 1 + leftDepth;
}
int result = 1 + min(leftDepth, rightDepth);
return result;

解法:

  • C++
class Solution {
public:int minDepth(TreeNode* root) {int result = 0;if(root == NULL) return 0;int leftDepth  = minDepth(root->left);   // 左int rightDepth = minDepth(root->right);  // 右if(root->left == NULL && root->right != NULL){return rightDepth + 1;}if(root->left != NULL && root->right == NULL){return leftDepth + 1;}result = 1 + min(leftDepth, rightDepth);return result;}
};

二叉树 — 完全二叉树的节点数量

题目链接:222. 完全二叉树的节点个数 - 力扣(LeetCode)

题目要求:

给你一棵 完全二叉树 的根节点 root ,求出该树的节点个数。

完全二叉树 的定义如下:在完全二叉树中,除了最底层节点可能没填满外,其余每层节点数都达到最大值,并且最下面一层的节点都集中在该层最左边的若干位置。若最底层为第 h 层,则该层包含 1~ 2h 个节点。

示例 1:

img

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

示例 2:

输入:root = []
输出:0

示例 3:

输入:root = [1]
输出:1

**思路:**可以使用层序遍历(只需要在遍历每一层时,记录节点的个数就可以),

使用递归的写法和求二叉树的深度写法类似,顺序依旧是后序(左右中)

1、确定递归的参数和返回值

int getNodesNum(TreeNode* cur)

2、确定终止条件(如果为空姐点的话,就返回 0,表示节点数量为 0)

if(cur == NULL) return 0;

3、确定单层递归的逻辑

int leftNum  = getNodesNum(cur->left);  // 左
int rightNum = getNodesNum(cur->right); // 右
int treeNum  = leftNum + rightNum + 1;  // 中
return treeNum;

解法:

  • C++
class Solution {
public:int countNodes(TreeNode* root) {if(root == NULL) return 0;int leftNum  = countNodes(root->left);int rightNum = countNodes(root->right);int result = leftNum + rightNum + 1;return result;}
};

示例 3:*

输入:root = [1]
输出:1

**思路:**可以使用层序遍历(只需要在遍历每一层时,记录节点的个数就可以),

使用递归的写法和求二叉树的深度写法类似,顺序依旧是后序(左右中)

1、确定递归的参数和返回值

int getNodesNum(TreeNode* cur)

2、确定终止条件(如果为空姐点的话,就返回 0,表示节点数量为 0)

if(cur == NULL) return 0;

3、确定单层递归的逻辑

int leftNum  = getNodesNum(cur->left);  // 左
int rightNum = getNodesNum(cur->right); // 右
int treeNum  = leftNum + rightNum + 1;  // 中
return treeNum;

解法:

  • C++
class Solution {
public:int countNodes(TreeNode* root) {if(root == NULL) return 0;int leftNum  = countNodes(root->left);int rightNum = countNodes(root->right);int result = leftNum + rightNum + 1;return result;}
};

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言扫盲

文章目录 C版本C语言特征GCCprintf数据类型函数指针内存管理void指针 Struct结构和Union结构typedef预处理器make工具cmake工具Projectintegral of sinc functionemulator embedded systeman event schedule 补充在线Linux终端安装Linux参考 建议还是国外教材学习…人家的PPT比…

【ESP32】Arduino开发 | I2C控制器+I2C主从收发例程

有关I2C控制器的详细介绍放在了IDF开发的文章中&#xff0c;跳转栏目目录可以找到对应的文章。 1. API Arduino启动时就已经实例化了两个I2C设备类&#xff0c;分别对应Wire和Wire1对象。 1.1 初始化 bool begin(int sda, int scl, uint32_t frequency0); // returns true, i…

【2023工业3D异常检测文献】PointCore: 基于局部-全局特征的高效无监督点云异常检测器

PointCore: Efficient Unsupervised Point Cloud Anomaly Detector Using Local-Global Features 1、Background 当前的点云异常检测器可以分为两类&#xff1a; &#xff08;1&#xff09;基于重建的方法&#xff0c;通过自动编码器重建输入点云数据&#xff0c;并通过比较原…

召回09 双塔模型+自监督学习

引入&#xff1a; 自监督学习改进双塔模型&#xff0c;可以提升业务指标。自监督学习是把物品塔学习得更习的更好。 长尾物品的曝光和点击数量太少&#xff0c;训练的样本次数不够。自监督可以更好地学习长尾数据的物品表征。 双塔模型的训练&#xff1a; 线上召回的时候不用纠…

【tbNick专享】虚拟机域控、成员服务器、降级等管理

在 VMware 中完成四台域控服务器、一台成员服务器的创建、降级域控为成员服务器&#xff0c;并创建子域的操作。 1. 创建四台域控和一台成员服务器 1.1 在 VMware 中创建虚拟机 启动 VMware Workstation&#xff1a; 打开 VMware Workstation&#xff0c;点击 “创建新的虚拟…

AIGC学习笔记—minimind详解+训练+推理

前言 这个开源项目是带我的一个导师&#xff0c;推荐我看的&#xff0c;记录一下整个过程&#xff0c;总结一下收获。这个项目的slogan是“大道至简”&#xff0c;确实很简。作者说是这个项目为了帮助初学者快速入门大语言模型&#xff08;LLM&#xff09;&#xff0c;通过从零…

十分钟实现内网连接,配置frp

十分钟实现内网连接&#xff0c;配置frp 一.frp是什么&#xff1f;其实是一款实现外网连接内网的一个工具&#xff0c;个人理解&#xff0c;说白了就像是teamviwer一样&#xff0c;外网能访问内网。 利用处于内网或防火墙后的机器&#xff0c;对外网环境提供 http 或 https 服…

CSS04-Chrome调试工具

Chrome 浏览器提供了一个非常好用的调试工具&#xff0c;可以用来调试我们的 HTML结构和 CSS 样式。

Redis实战(使用Scan,Lua脚本,一次扣多个库存,多线程并发使用,并发获取分布式锁,BItMap实现签到和在线统计)

1.使用Scan 2.lua脚本操作Redis 一次扣减一个商品库存 一次扣减多个商品的库存 Testvoid test100() {String key "product.1";stringRedisTemplate.opsForValue().set("product.1","10");stringRedisTemplate.opsForValue().set("produc…

在一个.NET Core项目中使用RabbitMQ进行即时消息管理

为了在一个.NET Core项目中使用RabbitMQ进行即时消息管理&#xff0c;以下是详细的全程操作指南&#xff0c;包括安装、配置、编写代码和调试使用。 一、安装RabbitMQ 1. 安装Erlang RabbitMQ依赖Erlang&#xff0c;因此需要先安装Erlang。 Windows: 下载并运行Erlang安装…

千亿数据-异地容灾-查询打印——MySQL大数据优化

1. 数据备份策略 - 定期全量备份&#xff1a;制定周期性的全量数据备份计划&#xff0c;确保数据的完整性。 - 增量备份&#xff1a;在全量备份之间进行增量备份&#xff0c;减少备份时间和存储空间。 2. 数据存储 - 分布式存储&#xff1a;利用分布式存储系统来存…

港科夜闻 | 香港科大颁授荣誉大学院士予五位杰出人士

关注并星标 每周阅读港科夜闻 建立新视野 开启新思维 1、香港科大颁授荣誉大学院士予五位杰出人士。香港科大9月24日向五位杰出人士颁授荣誉大学院士&#xff0c;他们分别为包弼德教授、简吴秋玉女士、高秉强教授、吴永顺先生及容永祺博士(按姓氏英文字母排序)。荣誉大学院士颁…

多无人机通信(多机通信)+配置ssh服务

目录 多机通信 设备 主从机通信设置 配置从机 配置主机 测试 正式启用 MAVROS通信 多机通信 多机通信是实现机器人编队的基础&#xff0c;通过网络搭建通信链路。我们这里用中心节点网络通信&#xff0c;所有数据需有经过中心节点&#xff0c;所以&#xff0c;中心节点…

C++黑暗迷宫

目录 开头程序程序的流程图程序游玩的效果下一篇博客要说的东西 开头 大家好&#xff0c;我叫这是我58。 程序 #include <iostream> #include <cstdlib> #include <ctime> using namespace std; struct near {int i;int ia;int ix;int iy;int iwalk; }; v…

单片机长短按简单实现

单片机长短按简单实现 目录 单片机长短按简单实现1 原理2 示例代码2.1 按键实现 3 测试log4 其他实现方式 1 原理 按键检测和处理的步骤如下&#xff1a; 1&#xff1a;定时扫描按键&#xff08;使用定时器定时扫描&#xff0c;也可以用软件延时或者系统心跳之类的方式&#…

信息安全工程师(21)安全协议

前言 安全协议是建立在密码体制基础上的一种交互通信协议&#xff0c;它运用密码算法和协议逻辑来实现认证、密钥分配、数据机密性、完整性和抗否认性等安全目标。 一、定义与目的 安全协议旨在确保网络环境中信息交换的安全性&#xff0c;通过密码技术和协议逻辑来保护数据的机…

AIGC入门:Comfyui整合包,解压即用!

整合包获取方式放在文末了 今天给大家分享的Comfyui的整合包&#xff0c;无需复杂的操作&#xff0c;解压即可使用。 整合包已经打包好了&#xff0c;获取方式放在文末&#xff0c;需要的朋友可以自行领取哦。 什么是Comfyui ComfyUI采用节点式的操作方式&#xff0c;这种方…

240922-局域网内通过SSH与SFTP访问RHEL服务器

要通过SFTP&#xff08;安全文件传输协议&#xff09;在局域网内访问一台RHEL服务器&#xff0c;您需要确保以下步骤都已经正确完成&#xff1a; A. 在RHEL服务器上配置SFTP服务 RHEL默认通过sshd服务提供SFTP功能&#xff0c;SFTP使用SSH协议进行文件传输&#xff0c;因此需要…

DarkLabel2.4版本导入MOT17数据集

目录 背景导入效果MOT17数据集说明DarkLabel导入视频导入gt文件 背景 做目标追踪&#xff0c;目前找了一圈开源工具&#xff0c;发现DarkLabel还是很好用的&#xff0c;提供自动目标跟踪&#xff0c;标注很方便。 由于目标追踪我用的是bytetrack&#xff0c;官网是用mot17数据…

Qt开发技巧(十)新版随机数,模拟鼠标移动,QTextEdit卡死问题,函数返回值,参数结构化,选项卡控件,窗体属性

继续讲一些Qt开发中的技巧操作&#xff1a; 1.新版随机数 Qt中有自己的随机数取值方法&#xff0c;Qt5.10以前使用qsrand方法&#xff0c; Qt5.10以后提供了新的类 QRandomGenerator QRandomGenerator64 管理随机数&#xff0c;使用更方便&#xff0c;尤其是取某个区间的随机数…