Kennem's Blog
  • 🏠主页
  • 🔍搜索
  • 📚文章
  • ⏱时间轴
  • 🔖标签
  • 🗂️分类
  • 🙋🏻‍♂️关于
主页 📚文章

💻技术

LeetCode 12/07 12/08 周赛/双周赛

LeetCode 12/07 12/08 周赛/双周赛 双周赛 T3 3377. 使两个整数相等的数位操作 题目总结: 给定两个整数 n 和 m,要求将 n 转变为 m,转变过程中需要满足以下条件: n 和 m 的数位长度相同; 可以对 n的数位执行以下操作: 将 n 中的任意一个 不是 9 的数位 增加 1; 将 n 中的任意一个 不是 0 的数位 减少 1; 转变过程中,n 任何中间状态都 不能是质数; 需要返回从 n 变为 m 的最小代价,代价为转变过程中所有 n 的值之和; 如果无法将 n 变为 m,返回 -1。 实现思路: 质数筛选: 使用线性筛法生成 1~10000 范围内的质数表,用布尔数组 st 标记每个数是否为质数,避免重复计算质数判断。 判断是否是质数: 定义函数 isPrime(x),通过 st[x] 快速判断一个数是否为质数。 特殊情况过滤: 如果 n 或 m 本身是质数,则直接返回 -1,因为无法满足条件。 最短路径求解: 使用 Dijkstra 算法 求解最小代价。 用优先队列(堆)存储当前的值和路径代价,起点为 n,终点为 m。 遍历当前数的每一位,分别尝试将该位增加或减少 1,生成新的数字 new_n: 如果 new_n 不为质数,并且更新的代价比当前已知代价更小,则将其加入堆中。 重复以上过程直到找到从 n 到 m 的最小代价。 返回结果: 如果在搜索中找到路径,返回最小代价;否则返回 -1 表示无法转换。 class Solution: def minOperations(self, n: int, m: int) -> int: N = 10000 primes = [] st = [False] * (N + 1) st[1] = True def sieve(n): for i in range(2, n + 1): if not st[i]: primes.append(i) for prime in primes: if i * prime > n: break st[i * prime] = True if i % prime == 0: break sieve(N) def isPrime(x): return not st[x] if isPrime(n) or isPrime(m): return -1 dis = [inf] * (N + 1) def dijkstra(): h = [(n, n)] dis[n] = n while h: dist, ver = heappop(h) if ver == m: return dist if dist > dis[ver]: continue str_n = list(str(ver)) for i in range(len(str_n)): ch = str_n[i] for delta in [-1, 1]: new_ch = chr(ord(ch) + delta) if '0' <= new_ch <= '9': new_n = int("".join(str_n[:i] + [new_ch] + str_n[i+1:])) if not isPrime(new_n) and dist + new_n < dis[new_n]: dis[new_n] = dist + new_n heappush(h, (dis[new_n], new_n)) return dis[m] res = dijkstra() return res if res < inf else -1 T4 3378. 统计最小公倍数图中的连通块数目 题目大意 题目给定一个整数数组 nums 和一个正整数 threshold,定义一张由 nums 的元素组成的图。如果两个节点对应的值 nums[i] 和 nums[j] 的最小公倍数(LCM)小于等于 threshold,则在图中将两个节点相连。要求返回图中 连通块的数量,即所有相互连通的节点组成的独立子图的数量。 ...

2024-12-08 · 6 分钟 · 2570 字 · updated: 2024-12-08 · ShowGuan

LeetCode Hot 100 精练🥸(2)

LeetCode Hot 100 精练🥸(2) 记忆中的东西一定会消退,真正留下的才是学到的,一定要及时回顾。 (21)139. 单词拆分 1、题目大意 给定字符串 s 和单词字典 wordDict,判断是否能用字典中的单词(可重复使用、无需全部使用)按顺序拼接得到 s。 ...

2024-12-08 · 16 分钟 · 7915 字 · updated: 2025-12-21 · ShowGuan

LeetCode Hot 100 精练🥸(3)

LeetCode Hot 100 精练🥸(3) 记忆中的东西一定会消退,真正留下的才是学到的,一定要及时回顾。 (41) 309. 买卖股票的最佳时机含冷冻期 给定一个整数数组prices,其中第 prices[i] 表示第 *i* 天的股票价格 。 ...

2024-12-08 · 10 分钟 · 4791 字 · updated: 2026-05-11 · ShowGuan

LeetCode Hot 100 精练🥸(4)

LeetCode Hot 100 精练🥸(4) 记忆中的东西一定会消退,真正留下的才是学到的,一定要及时回顾。 (61)31. 下一个排列 题目大意:给定一个整数数组,要求找出这个数组的下一个排列,即比当前排列大的下一个排列,如果不存在则返回字典序最小的排列。 ...

2024-12-08 · 10 分钟 · 4825 字 · updated: 2026-05-11 · ShowGuan

LeetCode Hot 100 精练🥸(5)

LeetCode Hot 100 精练🥸(5) 记忆中的东西一定会消退,真正留下的才是学到的,一定要及时回顾。 (81)104. 二叉树的最大深度 给定一个二叉树 root ,返回其最大深度。 二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。 ...

2024-12-08 · 12 分钟 · 5657 字 · updated: 2025-12-21 · ShowGuan

黑马头条(2)

黑马头条(2) 表结构分析 ap_article 文章基本信息表 ap_article_config 文章配置表 ap_article_content 文章内容表 三张表关系分析 从业务角度分析如何分表 滚屏分页的逻辑 表的拆分-垂直分表 垂直分表:将一个表的字段分散到多个表中,每个表存储其中一部分字段。 ...

2024-12-01 · 8 分钟 · 3798 字 · updated: 2024-12-01 · ShowGuan

LeetCode周赛425 & 144(241124)

LeetCode 11/24 11/25 周赛/双周赛 太长时间不参加周赛手生了很多,有时间就打,没时间刷熟 LeetCode Hot 100 + 面试题150 + LCR 双周赛 T3 3362. 零数组变换 III 题目大意 给定一个整数数组 nums 和二维数组 queries,每个操作 [li, ri] 可以将 nums[li] 到 nums[ri] 范围内的每个元素 最多减 1。 ...

2024-11-24 · 4 分钟 · 1921 字 · updated: 2024-11-24 · ShowGuan

黑马头条(1)

黑马头条(1) 微服务架构开发 Springboot Spring cloud Nacos Nacos 是一个由阿里巴巴开源的服务管理平台,专门用于微服务架构中的服务发现、配置管理和动态 DNS 服务。 环境搭建 目标:接口测试工具及前后端联调 类似今日头条 ...

2024-11-24 · 8 分钟 · 3916 字 · updated: 2024-11-24 · ShowGuan

面经(2)

面经(2) 腾讯面经 1. 自我介绍与项目 在自我介绍环节,建议突出以下几点: 背景和教育经历:说明你的专业、学校和毕业时间。如果有相关的学术成果或者奖项也可以提及。 实习和项目经验:重点介绍和面试岗位高度相关的实习或项目经历。比如,可以概括性地描述你负责的模块、使用的技术栈、解决的核心问题和取得的成效。 技术栈:可以具体介绍精通的编程语言(如Java、Python),掌握的框架或工具(如Spring Boot、Django),以及数据库和开发工具的经验(如MySQL、Git)。 项目细节:对于项目,可以选择一两个具有代表性的项目进行详细说明。建议结构如下: 项目背景及目标 你在项目中的角色及承担的主要工作 项目过程中遇到的挑战和你如何解决这些问题 项目的最终成果及其影响(数据和结果能帮助量化) 2. 操作系统 虚拟线程 虚拟线程(virtual thread)是现代编程语言(如Java)中为提高并发性能而引入的轻量级线程机制。相比传统线程,虚拟线程的创建和销毁代价更低,更适合高并发场景。 ...

2024-11-12 · 4 分钟 · 1557 字 · updated: 2024-11-12 · ShowGuan

RabbitMQ

RabbitMQ 同步通讯 和 异步通讯 同步调用 同步调用的问题: 拓展性差 性能下降 级联失败 异步调用 异步调用方式其实就是基于消息通知的方式,一般包含三个角色: 消息发送者:投递消息的人,就是原来的调用方 消息代理:管理、暂存、转发消息,可以理解为微信服务器 消息接收者:接受和处理消息的人,就是原来的服务提供方 支付服务不再同步调用业务关联度低的服务,而是发送消息通知到Broker。 ...

2024-11-05 · 11 分钟 · 5321 字 · updated: 2024-11-06 · ShowGuan

苍穹外卖前端开发(Day1)

苍穹外卖前端开发(Day1) node.js安装 配置全局下载包地址和缓存地址 npm config set prefix "E:x\nodejs\node_global" npm config set cache "E:\x\nodejs\node_cache" 最新的配置淘宝镜像的淘宝官方提供的方法 npm config set registry https://registry.npmmirror.com 安装Vue npm i @vue/cli -g 创建Vue项目 命令行创建(只能在cmd, 不能用powershell) vue create vue-demo-1 用网页的形式创建 vue ui Vue目录结构 node_modules:当前项目依赖的js包 assets:静态资源存放目录 components:公共组件存放目录 App.vue:项目的主组件,页面的入口文件 main.js:整个项目的入口文件 package.json:项目的配置信息、依赖包管理 vue.config.js:vue-cli配置文件 启动Vue项目工程 在Vue项目文件夹中: ...

2024-10-26 · 7 分钟 · 3134 字 · updated: 2024-10-26 · ShowGuan

苍穹外卖后端开发(Day12)

苍穹外卖后端开发(Day12) 工作台 名词解释: 营业额:已完成订单的总金额 有效订单:已完成订单的数量 订单完成率:有效订单数 / 总订单数 * 100% 平均客单价:营业额 / 有效订单数 新增用户:新增用户的数量 Apache POI Apache POI 是一个处理Microsoft Office 各种文件格式的开源项目。 ...

2024-10-24 · 3 分钟 · 1140 字 · updated: 2024-10-24 · ShowGuan

苍穹外卖后端开发(Day11)

苍穹外卖后端开发(Day11) Apache ECharts https://echarts.apache.org/zh/index.html 营业额统计 销量排名Top10 根据返回结果设计VO对象 SalesTop10ReportVO <select id="getSalesTop10" resultType="com.sky.dto.GoodsSalesDTO"> SELECT name, sum(od.number) number from order_detail od, orders o where od.order_id = o.id and o.status = 5 <if test="begin != null"> and o.order_time &gt; #{begin} </if> <if test="end != null"> and o.order_time &lt; #{end} </if> GROUP BY od.name ORDER BY number DESC LIMIT 10; </select>

2024-10-23 · 1 分钟 · 93 字 · updated: 2024-10-23 · ShowGuan

苍穹外卖后端开发(Day10)

苍穹外卖后端开发(Day10) Spring Task Spring Task 是 Spring 框架提供的任务调度工具,可以按照约定的时间自动执行某个代码逻辑。 cron 表达式 cron 表达式其实就是一个字符串,通过cron表达式可以定义任务触发的时间 ...

2024-10-21 · 2 分钟 · 799 字 · updated: 2024-10-21 · ShowGuan

苍穹外卖后端开发(Day7)

苍穹外卖后端开发(Day7) 缓存菜品 用户端小程序展示的菜品数据都是通过查询数据库获得,如果用户端访问量比较大,数据库访问的压力随之增大。 实现思路 通过Redis来缓存菜品数据,减少数据库查询操作。 ...

2024-10-18 · 2 分钟 · 836 字 · updated: 2024-10-18 · ShowGuan
« 上一页  下一页  »
© 2026 Kennem's Blog · Powered by Hugo & PaperMod
👤 Visitors: 👀 Views: