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

LeetCode 2680.最大或值:位运算

【LetMeFly】2680.最大或值:位运算

力扣题目链接:https://leetcode.cn/problems/maximum-or/

给你一个下标从 0 开始长度为 n 的整数数组 nums 和一个整数 k 。每一次操作中,你可以选择一个数并将它乘 2 。

你最多可以进行 k 次操作,请你返回 nums[0] | nums[1] | ... | nums[n - 1] 的最大值。

a | b 表示两个整数 a 和 b 的 按位或 运算。

 

示例 1:

输入:nums = [12,9], k = 1
输出:30
解释:如果我们对下标为 1 的元素进行操作,新的数组为 [12,18] 。此时得到最优答案为 12 和 18 的按位或运算的结果,也就是 30 。

示例 2:

输入:nums = [8,1,2], k = 2
输出:35
解释:如果我们对下标 0 处的元素进行操作,得到新数组 [32,1,2] 。此时得到最优答案为 32|1|2 = 35 。

 

提示:

  • 1 <= nums.length <= 105
  • 1 <= nums[i] <= 109
  • 1 <= k <= 15

很不错的一道题!位运算的与或异或都考察了。

解题方法一:前缀和

首先需要发现并理解的是:一定要每次都将“二进制下位数最长的那个数乘2”。

假如a二进制下是3位,b二进制下是2位,那么将b乘以2后和a或运算还是3位,一定不如将a乘以2变成2位大。

二进制下长度最长的数有多个,如何选择呢?

无所谓,每个都试试呗。我们只需要逮着一个数一直乘以2共k次,判断所有选择中结果最大的那个就好了。

这一听不是 O ( n 2 ) O(n^2) O(n2)吗,如何优化?

使用一个前缀和 p r e f i x [ i ] prefix[i] prefix[i]代表从下标 0 0 0或到下标 i i i这个元素的结果,“后缀和” s u f f i x [ i ] suffix[i] suffix[i]代表从最后一个元素或到下标 i i i的结果。

那么,如果将 n u m s [ i ] nums[i] nums[i]乘以 k k k 2 2 2的话,最终的或结果就是 p r e f i x [ i − 1 ] ∣ n u m s [ i ] < < k ∣ s u f f i x [ i + 1 ] prefix[i - 1]\ |\ nums[i] << k\ |\ suffix[i + 1] prefix[i1]  nums[i]<<k  suffix[i+1]

所有的这些结果中,最大的那个即为答案。

  • 时间复杂度 O ( l e n ( n u m s ) ) O(len(nums)) O(len(nums))
  • 空间复杂度 O ( l e n ( n u m s ) ) O(len(nums)) O(len(nums))

AC代码

C++
/** @Author: LetMeFly* @Date: 2025-03-21 15:09:09* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-03-21 15:17:06*/
#ifdef _WIN32
#include "_[1,2]toVector.h"
#endiftypedef long long ll;class Solution {
public:ll maximumOr(vector<int>& nums, int k) {vector<int> suffix(nums.size() + 1);for (int i = nums.size() - 1; i >= 0; i--) {suffix[i] = suffix[i + 1] | nums[i];}ll ans = 0;int prefix = 0;for (int i = 0; i < nums.size(); i++) {ans = max(ans, (ll)(nums[i]) << k | prefix | suffix[i + 1]);prefix |= nums[i];}return ans;}
};

解题方法二:位运算

方法一空间复杂度为 O ( n ) O(n) O(n),可否使用位运算优化?例如我单独将 n u m s [ i ] nums[i] nums[i]拎出来左移 k k k次的话,如何在 O ( 1 ) O(1) O(1)空间下快速判断出剩下所有元素的或值为多少?

假设数组中所有元素或运算的结果为 a l l O r allOr allOr

  • 对于 n u m s [ i ] nums[i] nums[i]二进制下的某个 1 1 1,如果其他元素中这一位也有出现过 1 1 1,那么拎出来 n u m s [ i ] nums[i] nums[i]后剩下元素这一位的或结果和 a l l O r allOr allOr相同

  • 对于 n u m s [ i ] nums[i] nums[i]二进制下的某个 1 1 1,如果其他元素中这一位没有出现过 1 1 1,那么拎出来 n u m s [ i ] nums[i] nums[i]后剩下元素这一位的或结果和 a l l O r allOr allOr不同

也就是说,我们只需要统计一下哪一位 1 1 1出现过最少两次( a l l 1 all1 all1 1 1 1的位代表至少有两个数这一位为 1 1 1),如果 n u m s [ i ] nums[i] nums[i]这一位为 1 1 1的话,依据 a l l 1 all1 all1的这一位是否为 1 1 1,就能判断出其他元素中是否存在这一位为 1 1 1的情况,就能得知除 n u m s [ i ] nums[i] nums[i]外其他元素这一位或运算的结果是否为 1 1 1了。

最后就剩下了一个问题:如何求出 a l l 1 all1 all1

同样使用前缀和的思路, p r e f i x prefix prefix代表从第一个元素到当前元素的上一个元素为止的或结果。

如果那么 p r e f i x & n u m s [ i ] prefix\ \&\ nums[i] prefix & nums[i]的某一位为 1 1 1的话,就代表 n u m s [ i ] nums[i] nums[i]和前面的数中的某些数这一位都为 1 1 1,也就是说这一位至少出现了两次 1 1 1

因此将 a l l 1 all1 all1或上 p r e f i x & n u m s [ i ] prefix\ \&\ nums[i] prefix & nums[i]即可。

这样,遍历到 n u m s [ i ] nums[i] nums[i]时, a l l O r ˆ n u m s [ i ] ∣ a l l 1 allOr\ \^\ nums[i]\ |\ all1 allOr  ˆnums[i]  all1即为所有元素除去 n u m s [ i ] nums[i] nums[i]后的或结果。

  • 时间复杂度 O ( l e n ( n u m s ) ) O(len(nums)) O(len(nums))
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++
/** @Author: LetMeFly* @Date: 2025-03-21 15:29:27* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-03-21 15:32:32* @Descriptions: Fake Time* @Descriptions: AC,100.00%,90.30%*/
typedef long long ll;class Solution {
public:ll maximumOr(vector<int>& nums, int k) {int allOr = 0, all1 = 0;for (int t : nums) {all1 |= allOr & t;allOr |= t;}ll ans = 0;for (int t : nums) {ans = max(ans, allOr ^ t | all1 | (ll)(t) << k);}return ans;}
};
Python
'''
Author: LetMeFly
Date: 2025-03-21 15:21:19
LastEditors: LetMeFly.xyz
LastEditTime: 2025-03-21 15:27:03
'''
from typing import Listclass Solution:def maximumOr(self, nums: List[int], k: int) -> int:allOr = all1 = 0for t in nums:all1 |= t & allOrallOr |= tans = 0for t in nums:ans = max(ans, t ^ allOr | all1 | t << k)return ans
Java
/** @Author: LetMeFly* @Date: 2025-03-21 15:32:20* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-03-21 15:34:12*/
class Solution {public long maximumOr(int[] nums, int k) {int allOr = 0, all1 = 0;for (int t : nums) {all1 |= t & allOr;allOr |= t;}long ans = 0;for (int t : nums) {ans = Math.max(ans, allOr ^ t | all1 | (long)t << k);}return ans;}
}
Go
/** @Author: LetMeFly* @Date: 2025-03-21 15:34:47* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-03-21 16:32:51* @Description: Go int和int64的位运算似乎几乎一点都不会自动转换类型*/
package mainfunc maximumOr(nums []int, k int) (ans int64) {allOr, all1 := 0, 0for _, t := range nums {all1 |= allOr & tallOr |= t}for _, t := range nums {ans = max(ans, int64(allOr) ^ int64(t) | int64(all1) | int64(t) << k)}return
}

End

说实话感觉这次官解写的不错,灵神有待加油啊。

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

相关文章:

LeetCode 2680.最大或值:位运算

【LetMeFly】2680.最大或值&#xff1a;位运算 力扣题目链接&#xff1a;https://leetcode.cn/problems/maximum-or/ 给你一个下标从 0 开始长度为 n 的整数数组 nums 和一个整数 k 。每一次操作中&#xff0c;你可以选择一个数并将它乘 2 。 你最多可以进行 k 次操作&#…...

Python——MySQL数据库编程

MySQL 是现在最流行的关系型数据库管理系统&#xff0c;在 WEB 开发中&#xff0c;MySQL 是最好的 RDBMS 应用软件之一。接下来&#xff0c;让我们快速掌握 python 使用 MySQL 的相关知识&#xff0c;并轻松使用 MySQL 数据库。 第1关&#xff1a;python数据库编程之创建数据库…...

AI 如何重塑数据湖的未来

在生成式 AI 与大模型技术飞速发展的今天&#xff0c;数据湖技术正迎来前所未有的挑战与机遇。海量非结构化数据的存储与处理、实时性与计算效率的平衡、高效存储的需求&#xff0c;已成为数据平台的核心难题。如何突破传统架构的局限&#xff0c;构建支持 AI 驱动的高效数据湖…...

C++ - 从零实现Json-Rpc框架-2(服务端模块 客户端模块 框架设计)

项⽬设计 本质上来讲&#xff0c;我们要实现的rpc&#xff08;远端调⽤&#xff09;思想上并不复杂&#xff0c;甚⾄可以说是简单&#xff0c;其实就是客⼾端想要完成某个任务的处理&#xff0c;但是这个处理的过程并不⾃⼰来完成&#xff0c;⽽是&#xff0c;将请求发送到服务…...

课程5. 迁移学习

课程5. 迁移学习 卷积神经网络架构ImageNet神经网络架构实践从 torchvision 加载模型在一个图像上测试预先训练的网络 迁移学习网络训练冻结层实践准备数据替换网络的最后一层冻结层网络训练获取测试样本的质量指标 课程计划&#xff1a; 流行的神经网络架构迁移学习 卷积神经…...

SATA(Serial Advanced Technology Attachment)详解

一、SATA的定义与核心特性 SATA&#xff08;串行高级技术附件&#xff09;是一种 用于连接存储设备&#xff08;如硬盘、固态硬盘、光驱&#xff09;的高速串行接口标准&#xff0c;取代了早期的PATA&#xff08;并行ATA&#xff09;。其核心特性包括&#xff1a; 高速传输&am…...

常用的 MyBatis 标签及其作用

MyBatis 是一个优秀的持久层框架&#xff0c;它通过 XML 或注解的方式将 Java 对象与数据库操作进行映射。在 MyBatis 的 XML 映射文件中&#xff0c;可以使用多种标签来定义 SQL 语句、参数映射、结果映射等。以下是一些常用的 MyBatis 标签及其作用&#xff1a; 1. 基本标签 …...

Blender配置渲染设置并输出动画

在Blender中&#xff0c;渲染设置和渲染动画的选项位于不同的面板中。以下是具体步骤&#xff1a; 渲染设置 渲染设置用于配置输出格式、分辨率、帧率等参数。 打开右侧的 属性面板&#xff08;按 N 键可切换显示&#xff09;。 点击 “输出属性” 选项卡&#xff08;图标是…...

网络故障排查指南:分治法与排除法结合的分层诊断手册

目录 一、排查方法论&#xff1a;分治法与排除法的结合 1. 分治法&#xff08;Divide and Conquer&#xff09; 2. 排除法&#xff08;Elimination&#xff09; 二、分层诊断实战手册 1. 物理层排查&#xff08;设备与线路&#xff09; 硬件检测三板斧 运维经验 2. 网络…...

【万字总结】前端全方位性能优化指南(三)——GPU渲染加速、WebGPU、OffscreenCanvas多线程渲染

theme: condensed-night-purple 前言 当每秒60帧的流畅渲染遭遇百万级多边形场景,传统CPU绘图如同单车道上的赛车——即便引擎轰鸣,依然难逃卡顿困局。现代GPU加速技术将渲染任务从「单车道」扩展到「八车道」,本章以分层爆破、API革命、线程联邦为技术支柱,拆解如何通过G…...

报错 - redis - Unit redis.service could not be found.

报错&#xff1a; Unit redis.service could not be found.Could not connect to Redis at 127.0.0.1:6379: Connection refused解决方法&#xff1a; 检查状态、有必要的话 重新安装 Linux 上查看状态 systemctl status redis显示以下内容&#xff0c;代表正常服务 出现下面…...

Windows系统本地部署OpenManus对接Ollama调用本地AI大模型

文章目录 前言1. 环境准备1.1 安装Python1.2. 安装conda 2. 本地部署OpenManus2.1 创建一个新conda环境2.2 克隆存储库2.3 安装依赖环境 3. 安装Ollama4. 安装QwQ 32B模型5. 修改OpenManus配置文件6. 运行OpenManus7.通过网页使用OpenManus8. 安装内网穿透8.1 配置随机公网地址…...

【递归,搜索与回溯算法篇】- 名词解释

一. 递归 1. 什么是递归&#xff1f; 定义&#xff1a; 函数自己调用自己的情况关键点&#xff1a; ➀终止条件&#xff1a; 必须明确递归出口&#xff0c;避免无限递归 ➁子问题拆分&#xff1a; 问题需能分解成结构相同的更小的子问题缺点&#xff1a; ➀栈溢出风险&#x…...

【设计模式】装饰模式

六、装饰模式 装饰(Decorator) 模式也称为装饰器模式/包装模式&#xff0c;是一种结构型模式。这是一个非常有趣和值得学习的设计模式&#xff0c;该模式展现出了运行时的一种扩展能力&#xff0c;以及比继承更强大和灵活的设计视角和设计能力&#xff0c;甚至在有些场合下&am…...

c库、POSIX库、C++库、boost库之间的区别和联系

文章目录 一、区别1. 定义和来源2. 功能范围3. 可移植性4. 语言支持5. 维护和更新 二、联系1. 相互补充2. 部分功能重叠3. 共同促进编程发展4. 代码兼容性 三、总结 一、区别 1. 定义和来源 C 库函数&#xff1a;由 ANSI C 和 ISO C 标准定义&#xff0c;是 C 语言编程的基础…...

算法及数据结构系列 - 树

系列文章目录 算法及数据结构系列 - 二分查找 算法及数据结构系列 - BFS算法 算法及数据结构系列 - 动态规划 算法及数据结构系列 - 双指针 算法及数据结构系列 - 回溯算法 文章目录 树框架树遍历框架N叉树遍历框架 经典题型124.二叉树的最大路径和105.从前序与中序遍历序列构造…...

go安装lazydocker

安装 先安装go环境 https://blog.csdn.net/Yqha1/article/details/146430281?fromshareblogdetail&sharetypeblogdetail&sharerId146430281&sharereferPC&sharesourceYqha1&sharefromfrom_link 安装lazydocker go install github.com/jesseduffield/laz…...

《深度学习》——YOLOv3详解

文章目录 YOLOv3简介YOLOv3核心原理YOLOv3改进YOLOv3网络结构 YOLOv3简介 YOLOv3&#xff08;You Only Look Once, version 3&#xff09;是一种先进的实时目标检测算法&#xff0c;由 Joseph Redmon 和 Ali Farhadi 开发。它在目标检测领域表现出色&#xff0c;具有速度快、精…...

使用spring-ai-ollama访问本地化部署DeepSeek

创建SpringBoot工程&#xff0c;引入依赖 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"htt…...

Kafka消息自定义序列化

文章目录 1. 默认序列化2.自定义序列化3.示例4.自定义解序列化器 1. 默认序列化 在网络中发送数据都是以字节的方式&#xff0c;Kafka也不例外。Apache Kafka支持用户给broker发送各种类型的消息。它可以是一个字符串、一个整数、一个数组或是其他任意的对象类型。序列化器(se…...

使用Systemd管理ES服务进程

Centos中的Systemd介绍 CentOS 中的 Systemd 详细介绍 Systemd 是 Linux 系统的初始化系统和服务管理器&#xff0c;自 CentOS 7 起取代了传统的 SysVinit&#xff0c;成为默认的初始化工具。它负责系统启动、服务管理、日志记录等核心功能&#xff0c;显著提升了系统的启动速…...

编程语言选择分析:C#、Rust、Go 与 TypeScript 编译器优化

编程语言选择分析&#xff1a;C#、Rust、Go 与 TypeScript 编译器优化 在讨论编程语言的选择时&#xff0c;特别是针对微软的 C# 和 Rust&#xff0c;以及谷歌的 Go 语言&#xff0c;以及微软试图通过 Go 来拯救 TypeScript 编译器的问题&#xff0c;我们可以从多个角度来分析和…...

使用粘贴控件

HarmonyOS 5.0.3(15) 版本的配套文档&#xff0c;该版本API能力级别为API 15 Release 文章目录 约束与限制开发步骤 粘贴控件是一种特殊的系统安全控件&#xff0c;它允许应用在用户的授权下无提示地读取剪贴板数据。 在应用集成粘贴控件后&#xff0c;用户点击该控件&#xf…...

MySQL 客户端连不上(1045 错误)原因全解析

MySQL 客户端连不上(1045 错误)原因全解析 在我们学习 MySQL 或从事 MySQL DBA 工作期间,时常会遇到:“我尝试连接到 MySQL 并且收到1045 错误,但我确定我的用户和密码都没问题”。 不管你现在是否是高手还是高高手,都不可避免曾经在初学的时候犯过一些很初级的错误,例…...

麒麟系列Linux发行版探秘

以下内容摘自《银河麒麟操作系统进阶应用》一书。 银河麒麟操作系统&#xff08;Kylin&#xff09; 银河麒麟&#xff08;Kylin&#xff09;操作系统是中国自主研发的一款基于Linux内核的操作系统。它的发展历程可以追溯到2002年&#xff0c;最初由国防科技大学主导研发&…...

刘强东突然发声:不该用算法压榨最底层兄弟!东哥,真正的人民企业家

今天忙了一天&#xff0c;很累&#xff0c;准备睡觉的时候&#xff0c;看到网上盛传的刘强东的朋友圈&#xff0c;东哥又在朋友圈发文了。 说实话&#xff0c;看完之后&#xff0c;感动&#xff0c;真的感动。 尤其是当我看到这两句话的时候。 1、我们所学的知识、商业模式、技…...

信息收集与问答系统流程分析与改进建议

现有系统的问题与局限 1. 资源管理问题 二元决策机制过于简化&#xff1a;当前系统仅在令牌预算耗尽时才进入Beast Mode&#xff0c;缺乏渐进式资源分配策略缺少早期预算规划&#xff1a;没有基于问题复杂度的初始资源分配机制缺乏优先级资源分配&#xff1a;所有问题和策略消…...

【人工智能】如何理解transformer中的token?

如何理解transformer中的token? **一、Token在Transformer中的作用****二、文本分词的常见方法****1. 基于词典的分词&#xff08;Dictionary-based Tokenization&#xff09;****2. 子词分词&#xff08;Subword Tokenization&#xff09;****(1) WordPiece算法****(2) BPE&a…...

Spring Boot 集成 Kafka 消息发送方案

一、引言 在 Spring Boot 项目中,Kafka 是常用的消息队列,可实现高效的消息传递。本文介绍三种在 Spring Boot 中使用 Kafka 发送消息的方式,分析各自优缺点,并给出对应的 pom.xml 依赖。 二、依赖引入 在 pom.xml 中添加以下依赖: <dependencies><!-- Sprin…...

Hadoop•HDFS的Java API操作

听说这是目录哦 上传文件到HDFS&#x1f308;一、下载Windows版本的JDK和Hadoop二、配置物理机环境变量三、创建项目四 、添加依赖五、新建java类六、创建文件七、打开集群八、选中、运行 从HDFS下载文件&#x1fa90;一、写代码二、HDFS要个文件三、物理机要个文件夹&#xff…...

电脑如何设置几分钟后自动关机

摘要&#xff1a;本文提供Windows、macOS和Linux系统设置定时自动关机的详细方法。 目录 一、Windows系统设置方法 设置定时关机 取消关机计划 二、macOS系统设置方法 设置定时关机取消关机计划 三、Linux系统设置方法 设置定时关机 取消关机计划 四、注意事项五、扩展&#x…...

固定公网 IP

固定公网 IP 是指为用户分配一个长期不变且可从互联网直接访问的 IP 地址&#xff0c;具有以下重要作用&#xff1a; 1. 搭建服务器 网站托管&#xff1a;可用于托管网站、博客或电子商务平台。 应用服务器&#xff1a;支持运行邮件服务器、游戏服务器、数据库等。 远程访问&…...

Linux安装go环境

安装一个lazydocker&#xff0c;根据文档需要先安装go环境 https://github.com/jesseduffield/lazydocker 官方文档解析 https://go.dev/doc/install 文档内容如下&#xff0c;一共三步 1.删除先前安装的go&#xff0c;解压下载的go压缩包到/usr/local目录 2.添加环境变量&…...

Git的基本使用

Git的基本使用 前言 &#xff1a;为什么使用GitGit基本操作1. 初始化2. Git分区3. 认识.git目录4. git基本操作 Git分支管理1. 基本操作2. Git分支设计规范 Git 标签管理1. Git标签的使用2. 标签使用规范3. Git标签与分支的区别 分离头指针问题1. 分离头指针问题的风险2. 分离头…...

鸿蒙Flutter开发故事:不,你不需要鸿蒙化

在华为牵头下&#xff0c;Flutter 鸿蒙化如火如荼进行&#xff0c;当第一次看到一份上百个插件的Excel 列表时&#xff0c;我也感到震惊&#xff0c;排名前 100 的插件赫然在列&#xff0c;这无疑是一次大规模的军团作战。 然后&#xff0c;参战团队鱼龙混杂&#xff0c;难免有…...

Mysql:关于命名

1. 命名的对象&#xff1a;库名、表名、列名、索引名 2. 用反引号包裹的情况下&#xff0c;命名时不允许使用空白字符、反引号&#xff0c;其它字符均可 3. 无反引号包裹的情况下&#xff0c;命名时仅允许使用&#xff1a;$、_、数字、大小写字母、中文字符(已知win系统支持)…...

JAVA————十五万字汇总

JAVA语言概述 JAVA语句结构 JAVA面向对象程序设计&#xff08;一&#xff09; JAVA面向对象程序设计&#xff08;二&#xff09; JAVA面向对象程序设计&#xff08;三&#xff09;工具类的实现 JAVA面向对象程序设计&#xff08;四&#xff09;录入异常处理 JAVA图形用户界面设…...

Chrome-Edge-IDEA-Win 常用插件-工具包

Chrome-Edge-IDEA-Win 常用插件-工具包 Chrome-Edge-IDEA-Win 常用插件-工具包谷歌插件chropathJSONViewOctotree - GitHub code treeXPath Helper书签侧边栏篡改猴Print Edit WEEdge浏览器插件IDEA插件CodeGlance Pro 代码迷你缩放图插件Alibaba Cloud ToolkitAlibaba Java Co…...

DeepSeek-R1论文深度解析:纯强化学习如何引爆LLM推理革命?

技术突破&#xff1a;从“无监督”到“自主进化”的跨越 paper &#xff1a;https://arxiv.org/pdf/2501.12948目录 技术突破&#xff1a;从“无监督”到“自主进化”的跨越1 DeepSeek-R1-Zero&#xff1a; RLnoSFT1.1 R1-Zero&#xff1a; GRPO&#xff08;Group Relative Po…...

最新!Ubuntu Docker 安装教程

源自: AINLPer&#xff08;每日干货分享&#xff01;&#xff01;&#xff09; 编辑: ShuYini 校稿: ShuYini 时间: 2025-3-1 更多&#xff1a;>>>>大模型/AIGC、学术前沿的知识分享&#xff01; 看到很多部署大模型的时候&#xff0c;都是基于docker安装部署的。…...

【Javascrip】Javascript练习01 REST API using Express.js.

针对该问题的项目路径 要求部分 what you need to doReview the tasks provided in the section below.Obtain the boilerplate code.Use your local development environment to implement a solution.Upload your solution for marking via Gradescope. There is no attempt…...

visual studion 2022如何使用PlaySound()

书籍&#xff1a;《windows程序设计(第五版)》的开始 环境&#xff1a;visual studio 2022 内容&#xff1a;HELLOWIN程序 说明&#xff1a;以下内容大部分来自腾讯元宝。 在Visual Studio 2022中使用PlaySound()函数播放音频&#xff0c;需完成以下步骤&#xff1a; ​1. 配…...

C++相关基础概念之入门讲解(下)

1. 引用 ​ int main() {const int a10;int& aaa;aa;cout<<aa<<endl; } 引用 不是新定义一个变量&#xff0c;而 是给已存在变量取了一个别名 &#xff0c;编译器不会为引用变量开辟内存空 间&#xff0c;它和它引用的变量 共用同一块内存空间&#xff08;初…...

从零开始学可靠消息投递:分布式事务的“最终一致性”方案

一、什么是可靠消息投递&#xff1f;—— 消息队列的“防丢宝典” 可靠消息投递 是指通过消息队列&#xff08;如 RocketMQ&#xff09;确保消息在生产、传输、消费过程中不丢失、不重复、有序到达。其核心目标是在分布式系统中保障数据最终一致性&#xff0c;常用于订单处理、…...

生物化学笔记:医学免疫学原理 免疫系统的组成与功能+克隆选择学说

免疫系统的组成与功能 克隆选择学说 克隆选择学说&#xff08;Clonal Selection Theory&#xff09;是免疫学的核心理论之一&#xff0c;由 麦克法兰伯内特&#xff08;Frank Macfarlane Burnet&#xff09; 在 1957 年提出&#xff0c;用于解释特异性免疫反应的机制。 基本概…...

SpringBoot最佳实践之 - 使用AOP记录操作日志

1. 前言 本篇博客是个人在工作中遇到的需求。针对此需求&#xff0c;开发了具体的实现代码。并不是普适的记录操作日志的方式。以阅读本篇博客的朋友&#xff0c;可以参考此篇博客中记录日志的方式&#xff0c;可能会对你有些许帮助和启发。 2. 需求描述 有一个后台管理系统…...

MySql中 一条select语句的执行流程

一条 SELECT 语句的执行流程涉及到数据库管理系统&#xff08;DBMS&#xff09;的多个组件和阶段。以下是一个更为详细的执行流程&#xff0c;以关系型数据库&#xff08;如 MySQL、PostgreSQL 等&#xff09;为例&#xff1a; 1. 客户端发送查询 用户输入&#xff1a;用户在客…...

图论——kruskal算法

53. 寻宝(第七期模拟笔试) 题目描述 在世界的某个区域,有一些分散的神秘岛屿,每个岛屿上都有一种珍稀的资源或者宝藏。国王打算在这些岛屿上建公路,方便运输。 不同岛屿之间,路途距离不同,国王希望你可以规划建公路的方案,如何可以以最短的总公路距离将 所有岛屿联通…...

【dify】 dify环境变量配置说明

这是一份Dify平台的环境变量配置文件&#xff0c;对平台的各项功能、服务和组件进行参数设置。以下是对其主要部分的详细解读&#xff1a; 1. 通用变量&#xff08;Common Variables&#xff09; CONSOLE_API_URL&#xff1a;控制台API的后端URL&#xff0c;用于拼接授权回调…...

如何在 Vue 项目中实现动态组件加载,有什么应用场景?

大白话如何在 Vue 项目中实现动态组件加载&#xff0c;有什么应用场景&#xff1f; 什么是动态组件加载 在 Vue 项目里&#xff0c;动态组件加载就是能够在程序运行时动态地决定要渲染哪个组件。打个比方&#xff0c;就像你去餐馆点菜&#xff0c;不同的时间你可能想吃不同的…...