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

python做网站快么/营销策略怎么写

python做网站快么,营销策略怎么写,网站建设人力资源分配,优化英文截图摘自湖南大学彭鹏老师的ppt。笔记也是根据他的ppt整理的。 动态规划 核心 用数组记录中间结果,避免重复计算 三角数塔问题 问题描述 给定一个三角形数塔,从顶部出发,每次只能移动到下一行的相邻元素。要求找到一条路径,…

截图摘自湖南大学彭鹏老师的ppt。笔记也是根据他的ppt整理的。

动态规划

核心

用数组记录中间结果,避免重复计算

三角数塔问题

问题描述

给定一个三角形数塔,从顶部出发,每次只能移动到下一行的相邻元素。要求找到一条路径,使得路径上的数字和最大。

假设有一个三角形数塔,如下所示:

    37 42 4 68 5 9 3

dp数组 dp[i][j]表示以matrix[i][j]为结尾的,最大路径的和

    310 712 14 1320 19 23 16

最后结果是23

解题思路

dp[i][j]=max(dp[i-1][j],dp[i-1][j+1])+matrix[i][j];

伪代码


int max_value(vector<vector<int>> &matrix ){vector<vector<int>> dp(matrix.size(),vector<int>(matrix.size()));dp[0][0] = matrix[0][0];for(int i=1;i<matrix.size();i++){dp[i][0] = dp[i-1][0] + matrix[i][0]; // 最左边的for(int j=1;j<i;j++){// 中间的dp[i][j] = max(dp[i-1][j-1],dp[i-1][j]) + matrix[i][j];}// 最右边的dp[i][i] = dp[i-1][i-1] + matrix[i][i];}return max(dp.back().begin(),dp.back().end());    
};

复杂度分析

时间复杂度:O(n^2),其中 n 是三角形的行数。
空间复杂度:O(n^2),其中 n 是三角形的行数。

最大字段和

问题描述

给定由n个整数(可能有负整数)组成的序列(a1, a2, …, an),最大子段和问题要求该序列形如 的最大值(1≤i≤j≤n),当序列中所有整数均为负整数时,其最大子段和为0。

示例

例如,序列(-20,11,-4,13, -5, -2)的最大子段和为 a2+a3+a4=20 。

dp[i]表示以a[i]开头的,从a[i]–>a.back()的最大子段和

dp数组

dp[i] = max(dp[i+1]+a[i],a[i]);

123456
a-2011-413-5-2
dp020913-5-2

所以最后答案是20

// 注意是后序
int max_sub_array(vector<int> &a){int n = a.size();vector<int> dp(n);dp.back() = a.back();int max_sum = a[0];for(int i=n-2;i>=0;i--){dp[i] = max(dp[i+1]+a[i],a[i]);max_sum = max(max_sum,dp[i]);}return max_sum;
}

复杂度分析

时间复杂度:O(n),其中 n 是序列的长度。
空间复杂度:O(n),其中 n 是序列的长度。

最长公共子序列

问题描述

给定两个字符串str1和str2,返回两个字符串的最长公共子序列(LCS)。

子序列是指从原字符串中删除若干个字符后,不改变剩余字符顺序得到的字符串。最长公共子序列是两个字符串所共同拥有的最长子序列。

例如,对于字符串"abcde"和"ace",最长公共子序列是"ace",因此长度为3。

示例

abcbdab
bdcaba

dp[i][j]表示str1[0:i]和str2[0:j]的最长公共子序列长度

startabcbdab
start00000000
b00111111
d00111222
c00122222
a01122233
b01223334
a01223344

所以最后答案是4 bdab

代码

int longest_common_subsequence(string &str1,string &str2){int n = str1.size();int m = str2.size();vector<vector<int>> dp(n+1,vector<int>(m+1,0));for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){if(str1[i-1] == str2[j-1]){dp[i][j] = dp[i-1][j-1]+1;}else{dp[i][j] = max(dp[i-1][j],dp[i][j-1]);}}}return dp[n][m];
}

复杂度分析

时间复杂度:O(nm),其中 n 和 m 分别是字符串 str1 和 str2 的长度。
空间复杂度:O(n
m),其中 n 和 m 分别是字符串 str1 和 str2 的长度。

01背包问题

问题描述

给定 n 种物品和一个容量为 w 的背包,每种物品都只有一件可用。第 i 种物品的体积是 vi,价值是 wi。求解将哪些物品装入背包,可使这些物品的总体积不超过背包容量,且总价值最大。输出最大价值。

示例

number=4 capacity=8

i1234
s (weight)2345
v (value)3456

dp数组

dp[i][j]表示,在总容量为j的情况下,在0~i个物品中,能获得的最大价值。

dp[i][j]=max(dp[i-1][j],dp[i-1][j-s[i]]+v[i])

012345678
1003333333
2003447777
3003447899
40034478910

代码

int max_value_in_knapsack(vector<int> &s,vector<int> &v,int capacity){int n = s.size();vector<vector<int>> dp(n+1,vector<int>(capacity+1,0));for(int i=1;i<=n;i++){for(int j=1;j<=capacity;j++){if(j>=s[i-1]){dp[i][j] = max(dp[i-1][j],dp[i-1][j-s[i-1]]+v[i-1]);}else{dp[i][j] = dp[i-1][j];}}}return dp[n][capacity];
}

复杂度分析

时间复杂度:O(nm),其中 n 和 m 分别是物品的数量和背包容积。
空间复杂度:O(n
m),其中 n 和 m 分别是物品的数量和背包容积。

贪心算法

选取局部最优解

优缺点

  • 优点:速度快,复杂度低
  • 缺点:需要证明是最优解

活动选择问题

问题描述

假设我们存在这样一个活动集合S={a1,a2,a3,a4,…,an},其中每一个活动ai都有一个开始时间si和结束时间fi保证(0≤si<fi),活动ai进行时,那么它占用的时间为[si,fi),现在这些活动占用一个共同的资源(教室),就是这些活动会在某一时间段里面进行安排,如果两个活动ai和aj的占用时间[si,fi),[sj,fj)不重叠,那么就说明这两个活动是兼容的,也就是说当sj>=fi或者si>=fj那么活动ai,aj是兼容的。在活动选择问题中,我们希望选出一个最大兼容活动集,即在同一间教室能安排数量最多的活动。

贪心策略

按照结束时间前的,放前面;结束时间一样的,开始时间小的放前面,然后依次相加

贪心证明

贪心的结果集是S, 剩下的集合是T,对于T中的任意一个元素b,都存在一个a属于S, 是a的结束时间大于b的开始时间。

在这里插入图片描述

代码

static bool cmp (const vector<int>&a, const vector<int>&b){return a[1]<b[1];}
int eraseOverlapIntervals(vector<vector<int>>& vct) {sort(vct.begin(),vct.end(),cmp);int endtime=vct.front()[1];int res=1;for(int i=1;i<vct.size();i++){if(endtime > vct[i][0]){}else{endtime=vct[i][1];res++;}}return res;}

建议

碰到这种问题,用动态规划也能做,而且如果对应的活动有权值,动态规划还一定是正确的。

  1. 对任务按照结束时间排序
  2. dp[i][j] i表示从0~i个任务,j表示空余时间,dp[i][j]表示最大解

哈夫曼编码

问题描述

给定一个由n个不同字符组成的字符串,请设计一个哈夫曼编码,使得使用该编码的编码长度最小。

哈夫曼树

  • 定义:给定n个权值作为n个叶子结点的权值,构造一棵二叉树,若该树的带权路径长度达到最小,称这样的二叉树为最优二叉树,也称为哈夫曼树(Huffman Tree)。

解法

  • 统计待编码字符串中每个字符出现的次数,并将这些次数作为权重存储在数组中。
  • 根据权重构建哈夫曼树。在构建过程中,每次从权重数组中取出两个最小的权重,将它们合并为一个新节点,新节点的权重为这两个节点权重之和。然后将新节点加入哈夫曼树,同时从权重数组中删除这两个节点。重复这个过程,直到权重数组为空。
  • 根据哈夫曼树生成哈夫曼编码。对于哈夫曼树的每个叶子节点,从根节点到叶子节点的路径上的每个节点对应一个0或1,将这些0和1按照从根节点到叶子节点的顺序连接起来,就得到了该叶子节点的哈夫曼编码。
  • 使用哈夫曼编码对字符串进行编码。将字符串中的每个字符替换为其哈夫曼编码,然后将编码后的字符串按照哈夫曼编码的规则进行传输或存储。

最小延迟调度问题

问题描述

任务集合S,∀i∈S,di 为截止时间,ti为加工时间,di , ti为正整数。一个调度f : S→N,f(i)为任务i 的开始时间。求最大延迟达到最小的调度,就是所有任务超过截止时间的和最小。

在这里插入图片描述

解决方案

按照结束时间di从小到大排序,安排时不留空余时间

贪心证明

最优解中可以不存在相邻的逆序任务,使得(i,j): f(i) < f(j) di > dj。 (真确解中,交换两个任意的任务,都会使得总任务拖延时间变长)。

找零问题

问题描述

考虑用最少的硬币找n美分零钱的问题。假设每种硬币的面额都是整数。设计贪心算法求解找零问题,假定有25美分、10美分、5美分和1美分4种面额的硬币。证明你的算法能找到最优解。

解决方案

按照先尽可能用25美分,然后尽可能用10美分,再尽可能用5美分,最后尽可能用1美分。

贪心证明

假设一个可能的解中,存在两个10,一个5,则可以用25代替,获取到一个更优解。同样递归,直到没有硬币组合能到25,对应着先用25美分的。

图基本算法

广度优先搜索

算法步骤

广度优先搜索(BFS,Breadth First Search),从初始点开始,逐层向前搜索,即第n层搜索未完成,不得进入下一层搜索。

深度优先搜索

算法步骤

深度优先搜索(DFS,Depth First Search),从初始点开始,对每一个可能的分支路径深入到不能再深入为止,而且每个节点只能访问一次

欧拉回路

判定条件

对于图上的任意节点,入度等于出度。

DFS解法

  • 从任意一个起始点v开始DFS遍历,直到再次到达点v,即寻找一个回路。
  • 将此回路定义为C,如果回路C中存在某个点x,其有出边不在回路中,则继续以此点x开始遍历寻找回路C’,将环C、C’连接起来也是一个大回路,如此往复,直到图G中所有的边均已经添加到回路中
  • 显然每条边只会返回一次,所以复杂度为O(E)

用人话说就是:

  1. 对任意一个节点A做DFS, 直到终点到了A,对遍历的边进行标记,把所有遍历的边去除。
  2. 对任意一个还有边的点B进行DFS,重复操作,直到所有边都被标记。
  3. 标记的边就是欧拉回路。

拓扑排序

算法步骤

  1. 找到所有入度为0的节点,并加入队列
  2. 依次从队列中取出节点,并将其指向的节点的入度减1,如果减1后,该节点的入度为0,则将其加入队列

最小生成树

把所有点都连接起来,使得生成树各边权值之和最小。

prim算法

算法步骤

  1. 选择一个节点作为起始点,并将其加入生成树中。
  2. 选择与生成树相连的,最小的边,将其加入生成树中。
  3. 重复步骤2,直到所有节点都被加入生成树中。
    在这里插入图片描述

复杂度

  • 使用邻接矩阵表示图: O(V^2) V是顶点数量,每次都要找最小的顶点
  • 使用邻接表表示图: O(ElogV) E是边的数量,每次都要找最小的顶点
    (加入新节点的时候,把新节点所有相邻的,不在生成树中的边添加进去)

Kruskal算法

算法步骤

  1. 按照边的权值从小到大排序
  2. 依次选择边,如果选择后不会形成环,则加入生成树中(使用并查集判断新加入的边是否会形成环)

瓶颈生成树

定义

一个无向图G上的瓶颈生成树是G上一种特殊的生成树。一个瓶颈生成树T上权重最大边的权重是G中所有生成树中最小的。T上最大权重的边的权重称为T的值。 就是生成树T,的最大权值,是G中所有生成树中,最大权值的最小值。

单源最短路径

松弛算法

在这里插入图片描述

说人话就是,对于点u --> v , 如果找到另外一个点x,使得u --> x --> v的路径更短,则更新u --> v的路径。后面的Dijkstra算法Bellman-Ford算法是基于这个算法的。

Dijkstra算法

算法步骤

  1. 创建一个距离列表,其中包含每个节点到起始节点的距离。起始节点的距离设置为0,其他节点的距离设置为无穷大。

  2. 创建一个已访问列表和一个待访问列表。起始节点被标记为已访问,其他所有节点都被标记为待访问。

  3. 对于每一个待访问的节点,计算它到起始节点的距离。如果这个距离比当前记录的距离还要短,那么就更新这个节点的距离。

  4. 从待访问列表中找到距离最小的节点,将其标记为已访问,并将其从待访问列表中移除。

  5. 重复步骤3和4,直到所有的节点都被访问过。

  6. 距离列表中记录的就是每个节点到起始节点的最短距离。

缺点

无法解决边值为负值

Bellman-Ford算法

算法步骤

  1. 为每个顶点 ’ v '初始化距离数组 dist[]为dist[v] = INFINITY。假设任何顶点(假设为“0”)作为源并分配dist = 0。
  2. 根据以下条件放松所有edges(u,v,weight)N-1次:
    • dist[v] = 最小值(dist[v],dist[u] + weight)
  3. 现在,再次放松所有边,即第N次,并基于以下两种情况,我们可以检测负循环:
    • 情况 1(存在负循环):对于任何边(u,v,权重),如果 dist[u] + weight < dist[v]
    • 情况 2(无负循环):情况 1 对于所有边均失败。

证明

N-1次可以求出最小路径

Bellman-ford算法思想是,进行一次遍历,遍历所有边,一次一定能找到一个距离start节点最近的点,N-1次之后,target节点最多和start节点之间有N-2个节点

N次距离减少,出现负循环回路

负权重的边又被遍历了一次

主定理

将规模为n的问题转化为a个规模为n/b的问题,花费的时间是O( n d n^d nd)
T(n)= a ∗ T ( n b ) + n d a*T(\frac{n}{b})+n^d aT(bn)+nd, 其中a>1 , b>1 , d>0

  • 当 a < b d b^d bd , T(n)=O( n d n^d nd)
  • 当 a = b d b^d bd , T(n)=O( n l o g b a ∗ l g n n^{log_{b} a}*lgn nlogbalgn)
  • 当 a > b^d , T(n)=O( n l o g b a n^{log_{b} a} nlogba)

不想推导,直接记住吧

例子

二分查找

  • T(n)= 2 T ( n 2 ) + 1 2T(\frac{n}{2})+1 2T(2n)+1
  • a=2 b=2 d=0 --> O(n)

归并排序合并

  • T(n)= 2 T ( n 2 ) + n 2T(\frac{n}{2})+n 2T(2n)+n
  • a=2 b=2 d=1 --> O(n*lgn)

递归式子

  • T(n)= 3 T ( n 4 ) + n l g n 3T(\frac{n}{4})+nlg{n} 3T(4n)+nlgn
  • a=3 b=4 d约为1.5 --> O(n*lgn)

红黑树

定义

  1. 每个节点要么是黑色,要么是红色;
  2. 根和叶子都是黑色的,所有的叶子都是NIL;
  3. 红色节点的父节点是黑色的;
  4. 从节点x到其所有后代叶子节点的所有路径中包含相同数量
    的黑节点。

相关文章:

算法设计与分析 笔记

截图摘自湖南大学彭鹏老师的ppt。笔记也是根据他的ppt整理的。 动态规划 核心 用数组记录中间结果&#xff0c;避免重复计算 三角数塔问题 问题描述 给定一个三角形数塔&#xff0c;从顶部出发&#xff0c;每次只能移动到下一行的相邻元素。要求找到一条路径&#xff0c;…...

mapreduce的工作原理

mapreduce的工作原理 MapReduce是一种编程模型&#xff0c;用于处理大规模数据集的并行运算。它的核心思想是"分而治之"&#xff0c;即把一个大数据集分解成多个小块&#xff0c;由多个处理单元并行处理&#xff0c;然后再将结果合并以得到最终结果。MapReduce模型包…...

vue中v-bind和v-model有什么区别

在Vue.js中&#xff0c;v-bind和v-model都是指令&#xff0c;用于实现数据和DOM元素之间的双向绑定&#xff0c;但它们的使用场景和功能有所区别。 v-bind: v-bind是一个通用指令&#xff0c;用于动态地绑定一个或多个属性&#xff0c;或者一个组件prop到表达式。它可以绑定任何…...

基于SpringBoot和PostGIS的某国基地可视化实战

目录 前言 一、Java后台开发设计与实现 1、模型层实现 2、控制层设计 二、WebGIS界面实现 1、列表界面的定义 2、全球基地可视化 三、成果展示 1、全球部署情况 2、亚太地区 3、欧洲基地分布 4、中东的部署 四、总结 前言 在之前的博客中&#xff0c;我们曾经对漂亮…...

为什么Linux服务器空间充足而实际上空间已满的原因

以下是一个典型的Linux服务器的磁盘空间使用情况表&#xff0c;展示了不同文件系统的大小、已用空间、可用空间和挂载点等信息 磁盘空间表的基本组成 Linux服务器的磁盘空间使用情况通常通过df命令查看&#xff0c;输出的表格包含以下几列&#xff1a; Filesystem&#xff1a…...

【LC刷题】DAY16:530 501 236

【LC刷题】DAY16&#xff1a;530 501 236 文章目录 【LC刷题】DAY16&#xff1a;530 501 236530. 二叉搜索树的最小绝对差 [link](https://leetcode.cn/problems/minimum-absolute-difference-in-bst/description/)501.二叉搜索树中的众数236. 二叉树的最近公共祖先 [link](htt…...

Vue 3 的 Teleport 组件实现跨层级通信

突破组件边界 - 使用 Vue 3 的 Teleport 组件实现跨层级通信 你可能已经熟悉了组件的基本概念:每个组件都是一个独立的单元,拥有自己的模板、样式和逻辑。但是,有时候我们需要在不同层级的组件之间进行交互,这就需要用到 Vue 3 中新引入的 Teleport 组件。 Teleport 组件可以…...

chromadb

Chroma是一款AI开源向量数据库&#xff0c;用于快速构建基于LLM的应用&#xff0c;支持Python和Javascript语言。具备轻量化、快速安装等特点&#xff0c;可与Langchain、LlamaIndex等知名LLM框架组合使用。 官网&#xff1a; https://www.trychroma.com/ https://docs.trychr…...

Gradle 自动化项目构建-Gradle 核心之 Project

一、前言 从明面上看&#xff0c;Gradle 是一款强大的构建工具&#xff0c;但 Gradle 不仅仅是一款强大的构建工具&#xff0c;它更像是一个编程框架。Gradle 的组成可以细分为如下三个方面&#xff1a; groovy 核心语法&#xff1a;包括 groovy 基本语法、闭包、数据结构、面…...

简单介绍 Kamailio cfg_rpc 模块

记得先加载 cfg_rpc 模块 loadmodule "cfg_rpc.so" kamailio 起来之后 运行 kamcmd cfg.list 可以得到&#xff1a; dispatcher: probing_threshold dispatcher: inactive_threshold dispatcher: ping_reply_codes rtpengine: rtpengine_disable_tout rtpengine: a…...

Windows 根据github上的环境需求,安装一个虚拟环境,安装cuda和torch

比如我们在github上看到一个关于运行环境的需求 Installation xxx系统Python 3.xxx CUDA 9.2PyTorch 1.9.0xxxxxx 最主要的就是cuda和torch&#xff0c;这两个会卡很多环境的安装。 我们重新走一遍环境安装。 首先创建一个虚拟环境 conda create -n 环境名字 python3.xxx…...

LeetCode 179. 最大数

更多题解尽在 https://sugar.matrixlab.dev/algorithm 每日更新。 组队打卡&#xff0c;更多解法等你一起来参与哦&#xff01; LeetCode 179. 最大数&#xff0c;难度中等。 排序 解题思路&#xff1a;现将 int 类型转成 str 类型&#xff0c;然后进行字符串比较&#xff0c…...

基于Java+SpringBoot+vue+elementui药品商城采购系统详细设计实现

基于JavaSpringBootvueelementui药品商城采购系统详细设计实现 &#x1f345; 作者主页 网顺技术团队 &#x1f345; 欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; &#x1f345; 文末获取源码联系方式 &#x1f4dd; &#x1f345; 查看下方微信号获取联系方式 承接各种…...

Pikachu靶场--文件上传

参考借鉴 Pikachu靶场之文件上传漏洞详解_皮卡丘文件上传漏洞-CSDN博客 文件上传漏洞&#xff1a;pikachu靶场中的文件上传漏洞通关_pikachu文件上传通关-CSDN博客 client check 在桌面新建一个文件夹&#xff0c;准备一个hello.php文件&#xff0c;文件写入如下代码 <?p…...

突破架构瓶颈:克服软件系统中的漂移和侵蚀

一种常见但不完美的比喻是将软件系统中的架构漂移和侵蚀与物理建筑的架构相比。虽然这个比喻很直观&#xff0c;但它存在一个根本性的误解&#xff0c;这也常常引发软件开发中的架构问题。 试想一下&#xff0c;一个设计良好的摩天大楼或房屋建成后&#xff0c;我们期望它基本保…...

每日练题(py,c,cpp).6_19,6_20

检验素数 from math import sqrt a int(input("请输入一个数&#xff1a;")) for i in range(2,int(sqrt(a))):if a%i 0:print("该数不是素数")breakelse: print("该数是素数")# # 1既不是素数也不是合数 # #可以用flag做标志位 # b int(…...

居中显示-css样式

在微信小程序中&#xff0c;要让一个盒子&#xff08;子元素&#xff09;在另一个盒子&#xff08;父元素&#xff09;内部居中显示&#xff0c;可以使用以下几种方法&#xff1a; 1. 使用 Flex 布局 微信小程序支持使用类似于 CSS Flexbox 的布局方式。以下是使用 Flex 布局的…...

生骨肉冻干喂猫比较好?热门、口碑好、值得入手生骨肉冻干力荐

随着科学养猫的普及&#xff0c;生骨肉冻干喂养越来越受欢迎&#xff0c;生骨肉冻干喂养对猫的好处很多&#xff0c;它符合猫咪的天性&#xff0c;可以提供全面的营养&#xff0c;保持牙齿和牙龈的健康&#xff0c;还有助于维持健康的消化系统。虽然许多猫主人看到了生骨肉冻干…...

【安卓13 源码】RescueParty救援机制

RescueParty机制正是在这个背景下诞生的&#xff0c;当它注意到系统或系统核心组件陷入循环崩溃状态时&#xff0c;就会根据崩溃的程度执行不同的救援行动&#xff0c;以期望让设备恢复到正常使用的状态。 开机后会自动重启&#xff0c;进入Recovery界面。经查找&#xff0c;是…...

详细介绍iutils.dll丢失的多个解决方法,一键快速修复丢失的iutils.dll文件

当用户遭遇“iutils.dll缺失”的提示时&#xff0c;这通常预示着依赖该库文件的程序将面临启动失败或功能受限的风险。DLL&#xff08;Dynamic Link Library&#xff0c;动态链接库&#xff09;文件无疑占据了核心地位。这些文件就如同建筑师手中的蓝图&#xff0c;为软件的构建…...

基于SpringBoot+Vue的美容美发在线预约系统的设计与实现【附源码】

毕业设计(论文) 题目&#xff1a;基于SpringBootVue的美容美发在线预约系统的设计与实现 二级学院&#xff1a; 专业(方向)&#xff1a; 班 级&#xff1a; 学 生&#xff1a; 指导教师&#xff…...

语言的数据结构:树与二叉树(二叉树篇)

语言的数据结构&#xff1a;树与二叉树&#xff08;二叉树篇&#xff09; 前言概念特别的二叉树满二叉树完全二叉树 存储结构顺序存储链式存储 查找方式 前言 上文说到了树&#xff0c;有人认为二叉树是树的每一个分支都有两个子节点。其实这也对。但二叉树在此基础上还做了限…...

若以框架学习(3),echarts结合后端数据展示,暂时完结。

前三天&#xff0c;参加毕业典礼&#xff0c;领毕业证&#xff0c;顿时感到空落落的失去感&#xff0c;没有工作&#xff0c;啥也没有&#xff0c;总感觉一辈子白活了。晚上ktv了一晚上&#xff0c;由于我不咋个唱歌&#xff0c;没心情&#xff0c;听哥几个唱了一晚上周杰伦&am…...

Spring Boot循环依赖(解决)

类与类之间的依赖关系形成了闭环&#xff0c;就会导致循环依赖问题的产生。举例来说&#xff0c;假设存在两个服务类A和服务类B&#xff0c;如果A通过依赖注入的方式引用了B&#xff0c;且B通过依赖注入的方式引用了A&#xff0c;那么A和B之间就存在循环依赖。 换成如下方法获…...

emqx4.4.3关于如何取消匿名登录,添加认证用户这件事

emqx4.4.3如何取消匿名登录&#xff0c;添加认证用户 emqx版本&#xff1a;4.4.3 背景&#xff1a;使用docker搭建完emqx后&#xff0c;使用 MQTTX 连接总是超时&#xff1a; 检查Java项目 是否有接口&#xff1a;https://XXXX:80/mqtt/auth? 若有&#xff0c;则具体逻辑查询…...

七天速通javaSE:第三天 程序控制结构:练习题

文章目录 前言一、基础1.计算从0~100之间奇数之和和偶数之和2. 用for循环输出0~1000之间能被5整除的数&#xff0c;每行输出三个 二、进阶1. 九九乘法表2.等边三角形 前言 本文主要讲解三种基本程序控制结构的练习题&#xff0c;以期熟练掌握顺序、选择、循环三种基本结构 一、…...

新增题目接口开发

文章目录 1.基本设计2.生成CRUD代码1.生成五张表的代码1.subject_info2.subject_brief3.subject_judge4.subject_multiple5.subject_radio 2.将所有的dao放到mapper文件夹3.将所有实体类使用lombok简化4.删除所有mapper的Param("pageable") Pageable pageable5.删除所…...

国内怎样使用GPT4 turbo

GPT是当前最为熟知的大模型&#xff0c;它优越的性能一直遥遥领先于其它一众厂商&#xff0c;然而如此优秀的AI在中国境内却是无法正常使用的。本文将告诉你4种使用gpt4的方法&#xff0c;让你突破限制顺利使用。 官方售价是20美元/月&#xff0c;40次提问/3小时&#xff0c;需…...

【语义分割】1-标注数据集-【单张图片】labelme标注json文件转mask

声明&#xff1a;我学习了b站&#xff1a;标注自己的语义分割数据集_哔哩哔哩_bilibili 并且复现了&#xff0c;记录了所思所得。 主要是说了&#xff1a; 做语义分割&#xff0c;数据集怎么用labelme标注成json文件&#xff0c;以及&#xff0c;json文件怎么转成mask 流程…...

c++: 理解编译器在背后所做的工作-工具篇

理解C模板以及编译器的优化是深入掌握C编程的重要部分。有一些其他工具和技术可以帮助你更好地理解编译器在背后所做的工作&#xff0c;特别是优化方面。以下是一些有用的工具和技术&#xff1a; 1. Compiler Explorer (Godbolt) Compiler Explorer 是一个非常流行的在线工具…...