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

0301 leetcode - 1502.判断是否能形成等差数列、 682.棒球比赛、657.机器人能否返回原点

1502.判断是否能形成等差数列

题目

给你一个数字数组 arr

如果一个数列中,任意相邻两项的差总等于同一个常数,那么这个数列就称为 等差数列

如果可以重新排列数组形成等差数列,请返回 true ;否则,返回 false

示例 1:

输入:arr = [3,5,1]
输出:true
解释:对数组重新排序得到 [1,3,5] 或者 [5,3,1] ,任意相邻两项的差分别为 2 或 -2 ,可以形成等差数列。

示例 2:

输入:arr = [1,2,4]
输出:false
解释:无法通过重新排序得到等差数列。

提示:

  • 2 <= arr.length <= 1000
  • -10^6 <= arr[i] <= 10^6

解题思路

只要对数组先进行排序,在比较每个相邻元素对差值是否相等就可以了。但是要注意,使用sort函数数组元素将按照转换为字符串的Unicode位点进行排序。不对。

sort()方法 相关知识点

在JavaScript中,Array.prototype.sort() 方法用于对数组的元素进行排序,并返回排序后的数组。这个方法会改变原数组。以下是sort()函数的基本用法和一些高级用法:

基本用法

array.sort([compareFunction])
  • array:需要排序的数组。
  • compareFunction(可选):用来指定按某种顺序排列的函数。如果省略,数组元素将按照转换为字符串的各个字符的Unicode位点进行排序。

不带比较函数的用法(重点注意)

如果不传递比较函数,数组元素将按照转换为字符串的Unicode位点进行排序,这可能导致以下非预期的排序结果:

let numbers = [20, 3, 5, 1, 2];
numbers.sort();
console.log(numbers); // 输出可能是 [1, 20, 2, 3, 5]

在上面的例子中,数字被转换成字符串,然后按照字符串的Unicode位点排序,所以20排在2前面。

带比较函数的用法

为了正确地排序数字,你应该提供一个比较函数。比较函数应该接受两个参数,通常称为ab,并且根据返回值来排序:

  • 如果返回值小于0,那么a会被排列到b前面。
  • 如果返回值等于0ab的顺序不变。
  • 如果返回值大于0b会被排列到a前面。

以下是一个升序排序数字数组的例子:

let numbers = [20, 3, 5, 1, 2];
numbers.sort(function(a, b) {return a - b;
});
console.log(numbers); // 输出 [1, 2, 3, 5, 20]

或者使用ES6的箭头函数:

let numbers = [20, 3, 5, 1, 2];
numbers.sort((a, b) => a - b);
console.log(numbers); // 输出 [1, 2, 3, 5, 20]

高级用法

你可以使用比较函数来根据不同的标准排序对象数组。例如,以下代码根据对象的age属性进行升序排序:

let people = [{ name: "Alice", age: 40 },{ name: "Bob", age: 30 },{ name: "Carol", age: 50 }
];people.sort((a, b) => a.age - b.age);
console.log(people);

注意事项

  • sort()方法在原数组上进行排序,不创建新数组。
  • 如果比较函数没有返回值,或者返回的是NaN,则元素的位置可能会不确定。
  • 在旧版浏览器中,sort()方法的实现可能不是稳定的,这意味着相等的元素可能不会保持它们原始的顺序。然而,从ECMAScript 2019(ES10)开始,所有主流JavaScript引擎的sort()实现都是稳定的。

使用sort()方法时,请确保理解它的行为,并根据需要提供适当的比较函数。

代码实现

/*** @param {number[]} arr* @return {boolean}*/
var canMakeArithmeticProgression = function(arr) {arr.sort((a, b) => a - b); // 按照数值大小进行排序var d=arr[1]-arr[0]for(let i=1;i<arr.length-1;i++){if(arr[i+1]-arr[i]!==d){return false}}return true
};

 682.棒球比赛

题目

你现在是一场采用特殊赛制棒球比赛的记录员。这场比赛由若干回合组成,过去几回合的得分可能会影响以后几回合的得分。

比赛开始时,记录是空白的。你会得到一个记录操作的字符串列表 ops,其中 ops[i] 是你需要记录的第 i 项操作,ops 遵循下述规则:

  1. 整数 x - 表示本回合新获得分数 x
  2. "+" - 表示本回合新获得的得分是前两次得分的总和。题目数据保证记录此操作时前面总是存在两个有效的分数。
  3. "D" - 表示本回合新获得的得分是前一次得分的两倍。题目数据保证记录此操作时前面总是存在一个有效的分数。
  4. "C" - 表示前一次得分无效,将其从记录中移除。题目数据保证记录此操作时前面总是存在一个有效的分数。

请你返回记录中所有得分的总和。

示例 1:

输入:ops = ["5","2","C","D","+"]
输出:30
解释:
"5" - 记录加 5 ,记录现在是 [5]
"2" - 记录加 2 ,记录现在是 [5, 2]
"C" - 使前一次得分的记录无效并将其移除,记录现在是 [5].
"D" - 记录加 2 * 5 = 10 ,记录现在是 [5, 10].
"+" - 记录加 5 + 10 = 15 ,记录现在是 [5, 10, 15].
所有得分的总和 5 + 10 + 15 = 30

示例 2:

输入:ops = ["5","-2","4","C","D","9","+","+"]
输出:27
解释:
"5" - 记录加 5 ,记录现在是 [5]
"-2" - 记录加 -2 ,记录现在是 [5, -2]
"4" - 记录加 4 ,记录现在是 [5, -2, 4]
"C" - 使前一次得分的记录无效并将其移除,记录现在是 [5, -2]
"D" - 记录加 2 * -2 = -4 ,记录现在是 [5, -2, -4]
"9" - 记录加 9 ,记录现在是 [5, -2, -4, 9]
"+" - 记录加 -4 + 9 = 5 ,记录现在是 [5, -2, -4, 9, 5]
"+" - 记录加 9 + 5 = 14 ,记录现在是 [5, -2, -4, 9, 5, 14]
所有得分的总和 5 + -2 + -4 + 9 + 5 + 14 = 27

示例 3:

输入:ops = ["1"]
输出:1

提示:

  • 1 <= ops.length <= 1000
  • ops[i]"C""D""+",或者一个表示整数的字符串。整数范围是 [-3 * 104, 3 * 104]
  • 对于 "+" 操作,题目数据保证记录此操作时前面总是存在两个有效的分数
  • 对于 "C""D" 操作,题目数据保证记录此操作时前面总是存在一个有效的分数

解题思路

使用栈去操作。在JavaScript中,数组可以很方便地模拟栈的行为,使用 push() 方法来添加元素到栈顶,使用 pop() 方法来移除栈顶元素。

相关知识点

1.栈(Stack)

栈是一种后进先出(Last In, First Out,LIFO)的数据结构。以下是如何使用数组来模拟栈的操作:

基本操作:
  • push(element):将元素添加到栈顶。
  • pop():移除栈顶元素,并返回被移除的元素。
  • peek() 或 top():返回栈顶元素,但不移除它。
  • isEmpty():检查栈是否为空。
  • size():返回栈中的元素数量。
示例代码:
let stack = []; // 使用数组来模拟栈// 入栈
stack.push(1);
stack.push(2);
stack.push(3);// 出栈
console.log(stack.pop()); // 输出 3// 查看栈顶元素
console.log(stack[stack.length - 1]); // 输出 2// 检查栈是否为空
console.log(stack.isEmpty()); // 输出 false// 获取栈的大小
console.log(stack.length); // 输出 2

2.队列(Queue)

队列是一种先进先出(First In, First Out,FIFO)的数据结构。以下是如何使用数组来模拟队列的操作:

基本操作:
  • enqueue(element):在队列的末尾添加一个新元素。
  • dequeue():移除队列的第一个元素,并返回被移除的元素。
  • front():返回队列的第一个元素,但不移除它。
  • isEmpty():检查队列是否为空。
  • size():返回队列中的元素数量。
示例代码:
let queue = []; // 使用数组来模拟队列// 入队
queue.push(1);
queue.push(2);
queue.push(3);// 出队
console.log(queue.shift()); // 输出 1// 查看队列的第一个元素
console.log(queue[0]); // 输出 2// 检查队列是否为空
console.log(queue.length === 0); // 输出 false// 获取队列的大小
console.log(queue.length); // 输出 2

请注意,虽然使用数组的 push() 和 shift() 方法可以模拟队列,但 shift() 操作的时间复杂度是 O(n),因为它需要移动所有其他元素。在实际应用中,为了提高性能,可以使用 Object 或者 Map 来实现队列,这样入队和出队操作都可以在 O(1) 时间内完成。

在ES6中,还可以使用 class 关键字来创建更正式的栈和队列类,为它们提供更清晰的方法和属性。

总之,栈和队列在js中其实可以合二为一,取最前面的元素就是用shift,最后一个就是pop。

3.reduce函数

reduce 函数是 JavaScript 数组的一个高阶函数,它对数组中的每个元素执行一个由你提供的“reducer”回调函数(升序执行),将其结果汇总为单个返回值。

array.reduce(function(accumulator, currentValue, currentIndex, array) {// ... 执行操作 ...
}, initialValue);
  • function(accumulator, currentValue, currentIndex, array):对于每个元素执行的回调函数。
    • accumulator:累加器累加回调的返回值; 它是上一次调用回调时返回的值,或者是提供的初始值(见下文)。
    • currentValue:数组中正在处理的当前元素。
    • currentIndex(可选):数组中正在处理的当前元素的索引。如果提供了 initialValue,则起始索引为 0,否则为 1。
    • array(可选):调用 reduce 的数组。
  • initialValue(可选):作为第一次调用回调函数时的第一个参数的值。如果没有提供初始值,则将使用数组中的第一个元素,并且 currentIndex 从 1 开始。

以下是一个使用 reduce 来计算数组中所有数字总和的例子:

const numbers = [1, 2, 3, 4, 5];const sum = numbers.reduce((accumulator, currentValue) => {return accumulator + currentValue;
}, 0); // 初始值为 0console.log(sum); // 输出 15

在这个例子中,reduce 函数遍历 numbers 数组,将每个元素加到累加器上,最终返回总和。

如果没有提供 initialValuereduce 将使用数组的第一个元素作为累加器的初始值,并从第二个元素开始遍历数组。

下面是一个没有提供初始值的例子:

const numbers = [1, 2, 3, 4, 5];const sum = numbers.reduce((accumulator, currentValue) => {return accumulator + currentValue;
});console.log(sum); // 输出 15

在这个例子中,reduce 从数组的第一个元素(1)开始作为累加器的初始值,然后从第二个元素(2)开始遍历数组。

reduce 函数非常强大,可以用于执行各种复杂的操作,比如将数组扁平化、计算对象数组的属性总和、按属性分组对象等。

代码实现

function calPoints(operations) {let stack = []; // 使用数组作为栈operations.forEach(op => {if (op === "C") {// "C" 操作:移除栈顶元素stack.pop();} else if (op === "D") {// "D" 操作:将栈顶元素加倍,并将结果压入栈stack.push(stack[stack.length - 1] * 2);} else if (op === "+") {// "+" 操作:将栈顶的两个元素相加,并将结果压入栈stack.push(stack[stack.length - 1] + stack[stack.length - 2]);} else {// 数字操作:将字符串转换为数字并压入栈stack.push(parseInt(op));}});// 计算栈中所有得分的总和return stack.reduce((sum, score) => sum + score, 0);
}

657.机器人能否返回原点

题目

在二维平面上,有一个机器人从原点 (0, 0) 开始。给出它的移动顺序,判断这个机器人在完成移动后是否在 (0, 0) 处结束

移动顺序由字符串 moves 表示。字符 move[i] 表示其第 i 次移动。机器人的有效动作有 R(右),L(左),U(上)和 D(下)。

如果机器人在完成所有动作后返回原点,则返回 true。否则,返回 false

注意:机器人“面朝”的方向无关紧要。 “R” 将始终使机器人向右移动一次,“L” 将始终向左移动等。此外,假设每次移动机器人的移动幅度相同。

示例 1:

输入: moves = "UD"
输出: true
解释:机器人向上移动一次,然后向下移动一次。所有动作都具有相同的幅度,因此它最终回到它开始的原点。因此,我们返回 true。

示例 2:

输入: moves = "LL"
输出: false
解释:机器人向左移动两次。它最终位于原点的左侧,距原点有两次 “移动” 的距离。我们返回 false,因为它在移动结束时没有返回原点。

提示:

  • 1 <= moves.length <= 2 * 104
  • moves 只包含字符 'U''D''L' 和 'R'

代码实现

/*** @param {string} moves* @return {boolean}*/
var judgeCircle = function(moves) {var length=moves.length;//如果字符串是奇数,必不可能回到原点。if(length%2===1) return false;//是偶数的时候 只要RL的个数相等和UD个数相等即可。var udCount=0;var rlCount=0;for(let i=0;i<length;i++){if(moves[i]==='U')udCount++;if(moves[i]==='D')udCount--;if(moves[i]==='R')rlCount++;if(moves[i]==='L')rlCount--;}if(udCount===0 && rlCount===0) return true;return false;
};

相关文章:

0301 leetcode - 1502.判断是否能形成等差数列、 682.棒球比赛、657.机器人能否返回原点

1502.判断是否能形成等差数列 题目 给你一个数字数组 arr 。 如果一个数列中&#xff0c;任意相邻两项的差总等于同一个常数&#xff0c;那么这个数列就称为 等差数列 。 如果可以重新排列数组形成等差数列&#xff0c;请返回 true &#xff1b;否则&#xff0c;返回 false…...

【03】STM32F407 HAL 库框架设计学习

【03】STM32F407 HAL 库框架设计学习 摘要 本文旨在为初学者提供一个关于STM32F407微控制器HAL&#xff08;Hardware Abstraction Layer&#xff09;库框架设计的详细学习教程。通过本文&#xff0c;读者将从零开始&#xff0c;逐步掌握STM32F407的基本知识、HAL库的配置步骤…...

React低代码项目:Redux 状态管理

吐司问卷&#xff1a;Redux 状态管理 Date: February 18, 2025 5:37 PM (GMT8) Redux 管理用户信息 命名规范&#xff1a; 以 Info 结尾表示获取Reudx信息&#xff0c;比如 useGetUserInfo.ts 以 data 结尾表示获取服务端信息&#xff0c;比如 useLoadQuestionData 采用 Re…...

Vue核心知识:动态路由实现完整方案

在Vue中实现动态路由&#xff0c;并结合后端接口和数据库表设计&#xff0c;是一个复杂的项目&#xff0c;需要多个技术栈和步骤的配合。以下将详细描述整个实现过程&#xff0c;包括数据库设计、后端接口设计、前端路由配置以及如何实现动态路由的功能。 目录 一、需求分析二…...

Linux安装jdk,node,mysql,redis

准备工作&#xff1a; 1.安装VMware软件&#xff0c;下载CentOs7镜像文件&#xff0c;在VMware安装CentOs7 2.宿主机安装Xshell用来操作linux 3. .宿主机安装Xftp用来在宿主机和虚拟机的linux传输文件 案例1&#xff1a;在 /home/soft文件夹解压缩jdk17&#xff0c;并配置环…...

数据库原理与使用基础教程

数据库原理与使用基础教程 大纲 数据库基础概述 什么是数据库&#xff1f;数据库管理系统&#xff08;DBMS&#xff09;概述数据库的类型数据库模型与结构 关系型数据库 关系型数据库简介表&#xff08;Table&#xff09;、字段&#xff08;Field&#xff09;、记录&#xff…...

GCC 与 Clang:两大编译器的全面对比与深度解析!

GCC 与 Clang&#xff1a;两大编译器的全面对比与深度解析&#xff01;&#x1f525; 你是否曾为选择编译器而纠结&#xff1f;GCC 和 Clang 作为 C/C 开发中最主流的编译器&#xff0c;它们各自有什么优势和特点&#xff1f;为什么有人说 Clang 更现代&#xff0c;而 GCC 更强…...

ue5 创建多列StreeView的方法与理解

创建StreeView的多列样式怎么就像是创建单行单列差不多?貌似就是在单行单列中加入了多列widget? 示例代码 DetailTabWidget #pragma once #include "TreeViewItemBase.h"class SDetailTabWidget : public SCompoundWidget {SLATE_BEGIN_ARGS(SDetailTabWidget){…...

GPT-4.5来了

https://chat.xutongbao.top/...

java后端开发day25--阶段项目(二)

&#xff08;以下内容全部来自上述课程&#xff09; 1.美化界面 private void initImage() {//路径分两种&#xff1a;//1.绝对路径&#xff1a;从盘符开始写的路径 D:\\aaa\\bbb\\ccc.jpg//2.相对路径&#xff1a;从当前项目开始写的路径 aaa\\bbb\\ccc.jpg//添加图片的时…...

【小羊肖恩】小羊杯 Round 2 C+K

题目链接&#xff1a;https://ac.nowcoder.com/acm/contest/100672#question C.是毛毛虫吗&#xff1f; 思路&#xff1a; 其实很简单&#xff0c;假设我们要满足题目所给条件&#xff0c;那么这个毛毛虫最坏情况下肯定是一条如下图所示的无向图 右端省略号为对称图形 &…...

计算机网络——详解TCP三握四挥

文章目录 前言一、三次握手1.1 三次握手流程1.2 tcp为什么需要三次握手建立连接&#xff1f; 二、四次挥手2.1 四次挥手流程2.2 为什么是四次&#xff0c;不是三次&#xff1f;2.3 为什么要等待2msl&#xff1f;2.4 TCP的保活计时器 前言 TCP和UDP是计算机网络结构中运输层的两…...

PHP实现国密SM4算法,银行系统加密算法,JAVA和PHP可相互转换(附完整源码)

最终实现效果&#xff1a;PHP生成加密串&#xff0c;JAVA代码中完成匹配 JAVA SM4库实现效果 /*** 签名** param content 请求报文体* param secret 密钥* return*/public static String sign(String content, String secret) {String charSet "UTF-8";String c…...

DILLEMA:扩散模型+大语言模型,多模态数据增强框架

引言&#xff1a;深度学习模型的鲁棒性测试需要全面且多样化的测试数据。现有的方法通常基于简单的数据增强技术或生成对抗网络&#xff0c;但这些方法在生成真实且多样化的测试数据集方面存在局限性。为了克服这些限制&#xff0c;DILLEMA框架应运而生&#xff0c;旨在通过结合…...

京东web 详情 cfe滑块分析

声明: 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01; 逆向分析 data response.json() pri…...

【Redis学习】Redis Docker安装,自定义config文件(包括RDB\AOF setup)以及与Spring Boot项目集成

【本文内容】 第1章&#xff1a;通过Docker安装Redis&#xff0c;并自定义config文件以及mount data目录。第2章&#xff1a;介绍Redis持久化到磁盘&#xff0c;有4种方式&#xff1a;RDB / AOF / NONE / RDB AOF。第3章&#xff1a;使用Server自带的redis-cli工具连接。第4章…...

Python 面向对象编程-继承与多态

目录 继承与多态 静态语言 vs 动态语言 小结 继承与多态 在OOP程序设计中&#xff0c;当我们定义一个class的时候&#xff0c;可以从某个现有的class继承&#xff0c;新的class称为子类&#xff08;Subclass&#xff09;&#xff0c;而被继承的class称为基类、父类或超类&a…...

AcWing 蓝桥杯集训·每日一题2025·5439. 农夫约翰真的种地

5439. 农夫约翰真的种地 题目描述 农夫约翰在他的农场种植了 N N N 个芦笋&#xff0c;编号 ( 1 ∼ N ) (1 \sim N) (1∼N)。 其中&#xff0c;第 i i i 个芦笋的初始高度为 h i h_i hi​&#xff0c;每经过一天高度会增长 a i a_i ai​。 给定一个 ( 0 ∼ N − 1 ) (0…...

如何将 Excel 数据转换为 SQL 脚本:从入门到实战

全文目录&#xff1a; 开篇语? 前言?? 目录?? 什么是 SQL 脚本&#xff1f;?? 为什么要将 Excel 转换为 SQL 脚本&#xff1f;??? 如何将 Excel 转换为 SQL 脚本 ?? 方法一&#xff1a;使用在线转换工具?? 方法二&#xff1a;通过 Excel VBA 编写脚本?? 方法三…...

0x05 部门功能开发日志技术

准备工作 开发规范 采用restful风格&#xff1a;representational state transfer&#xff0c;表述性状态转换&#xff0c;是一种软件架构风格 REST是风格&#xff0c;是约定方式&#xff0c;约定不是规定&#xff0c;可以打破 描述功能模块通常使用复数形式加s&#xff08;如…...

塔能物联运维:城市照明极端天气下的“定海神针”

在当今城市快速发展的进程中&#xff0c;城市照明系统的稳定性和可靠性在极端天气条件下愈发受到关注。而塔能物联运维平台的出现&#xff0c;为城市照明在各种复杂环境下的稳定运行提供了强有力的保障&#xff0c;让城市照明在极端天气下也能“稳如泰山”。 城市照明对于保障市…...

Transformer 代码剖析7 - 词元嵌入(TokenEmbedding) (pytorch实现)

一、类定义与继承关系剖析 1.1 代码结构图示 #mermaid-svg-9COHbtmHJhpiroHM {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-9COHbtmHJhpiroHM .error-icon{fill:#552222;}#mermaid-svg-9COHbtmHJhpiroHM .error-t…...

6.6.5 SQL访问控制

文章目录 GRANT授予权限REVOKE回收权限 GRANT授予权限 GRANT语句可以给用户授予权限&#xff0c;基本格式是GRANT 权限 TO 用户。在授权时&#xff0c;WITH GRANT OPTION是可选项&#xff0c;有此句话&#xff0c;被授予权限的用户还能把权限赋给其他用户。 REVOKE回收权限 RE…...

IDEA 使用codeGPT+deepseek

一、环境准备 1、IDEA 版本要求 安装之前确保 IDEA 处于 2023.x 及以上的较新版本。 2、Python 环境 安装 Python 3.8 或更高版本 为了确保 DeepSeek 助手能够顺利运行&#xff0c;您需要在操作系统中预先配置 Python 环境。具体来说&#xff0c;您需要安装 Python 3.8 或更高…...

React + TypeScript 实现 SQL 脚本生成全栈实践

React TypeScript 实现数据模型驱动 SQL 脚本生成全栈实践 引言&#xff1a;数据模型与 SQL 的桥梁革命 在现代化全栈开发中&#xff0c;数据模型与数据库的精准映射已成为提升开发效率的关键。传统手动编写 SQL 脚本的方式存在模式漂移风险高&#xff08;Schema Drift&#…...

用DeepSeek生成批量删除处理 PDF第一页工具

安装依赖库 在运行程序之前&#xff0c;请确保安装所需的库&#xff1a; pip install pymupdf python-docx Python 程序代码 import os import fitz # PyMuPDF from docx import Documentdef delete_pdf_first_page(input_path, output_path):"""删除 PDF…...

三个小时学完vue3(一)

Vue3 之前就学过一些&#xff0c;不过用的比较少&#xff0c;基本忘完了/(ㄒoㄒ)/~~ 跟着B站视频迅速回忆一下 创建一个Vue 3 应用 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport&…...

netty如何处理粘包半包

文章目录 NIO中存在问题粘包半包滑动窗口MSS 限制Nagle 算法 解决方案 NIO中存在问题 粘包 现象&#xff0c;发送 abc def&#xff0c;接收 abcdef原因 应用层&#xff1a;接收方 ByteBuf 设置太大&#xff08;Netty 默认 1024&#xff09;滑动窗口&#xff1a;假设发送方 25…...

最好Wordpree+Apache+PHP安装教程

前提需要 PHP的安装最少需要7.4以上Mysql的安装&#xff0c;直接默认最新版就行APache服务器&#xff08;HTTP服务器&#xff0c;只有用这个你的软件才能在服务器上运行&#xff09; 安装apache 安装 sudo apt install apache2查看防火墙 sudo ufw app list如果有 Apache那…...

0x02 js、Vue、Ajax

文章目录 js核心概念js脚本引入html的方式基础语法事件监听 Vuevue简介v-forv-bindv-if&v-showv-model&v-on Ajax js 核心概念 JavaScript&#xff1a;是一门跨平台、面向对象的脚本语言&#xff0c;用来控制网页行为实现交互效果&#xff0c;由ECMAScript、BOM、DOM…...

如何使用Docker搭建哪吒监控面板程序

哪吒监控(Nezha Monitoring)是一款自托管、轻量级的服务器和网站监控及运维工具,旨在为用户提供实时性能监控、故障告警及自动化运维能力。 文档地址:https://nezha.wiki/ 本章教程,使用Docker方式安装哪吒监控面板,在此之前,你需要提前安装好Docker. 我当前使用的操作系…...

智能图像处理平台:图片管理

接着我们讲图片管理&#xff0c;先实现图片基础的增删改查&#xff0c;再去考虑图像处理。 主要是&#xff0c;我们需要完成查询时&#xff0c;查询的图片的上传者的角色等级小于等于我们当前登陆账号。 后端controller&#xff1a; package com.llpp.controller;import cn.…...

如何使用Docker一键本地化部署LibrePhotos搭建私有云相册

文章目录 前言1.关于LibrePhotos2.本地部署LibrePhotos3.LibrePhotos简单使用4. 安装内网穿透5.配置LibrePhotos公网地址6. 配置固定公网地址 前言 你是不是也经常对着手机里那一堆珍贵的照片发愁&#xff0c;心里想着&#xff1a;‘这要是被谁偷偷看了可咋办&#xff1f;’别…...

删除idea recent projects 记录

1、退出idea&#xff08;一定要全部退出idea&#xff0c;要不然删除后&#xff0c;idea一退出&#xff0c;又保存上了&#xff09; 2、进入 C:\Users\Administrator\AppData\Roaming\JetBrains\IntelliJIdea2024.1\options 目录 根据不同的版本号 IntelliJIdea2024.1 这个地方…...

基因组突变数据分析-ClinVar数据库

探序基因肿瘤研究院 数据库简介&#xff1a;ClinVar是一个免费访问的公共数据库&#xff0c;记录了人类变异和表型之间的关系&#xff0c;并提供了支持性证据&#xff08;supporting evidence&#xff09;。ClinVar提供的变异临床意义&#xff08;clinical significance&#…...

windows 下 使用Python OpenCV针对 压缩的tiff 图像进行解压缩 并转换成多张jpeg 图像

文章大纲 Tif/Tiff 图像简介tif 后缀的文件中为什么可以嵌入多张图片Tif 图像 与 jpg 图像转换的要点参考使用的 GitHub 仓库链接tifffile 库的功能与其他库的区别代码实现 基于 tifffile参考文献Tif/Tiff 图像简介 TIFF(Tagged Image File Format)是一种灵活且可适应的文件…...

小皮网站搭建

前提&#xff1a;小皮的安装下载 1、在www目录下创建一个新的文件夹&#xff0c;用来存放网站源码&#xff1b; 2、安装数据库管理工具phpMyadmin 3、新建数据表 添加字段 4、创建网站 5、前端的登录代码 注册 后端php 网页展示 登录成功跳转welcome.php...

Java8面试

Java 8 有哪些新特性? &#x1f40e;Java 8五大神装特性&#x1f40e; Lambda表达式&#xff08;魔法调料&#xff09; 曼波觉得像速食魔法咒语&#xff01;(๑✧◡✧๑) // 传统写法&#xff08;像冗长菜谱&#xff09; new Thread(new Runnable() {public void run() {Syst…...

一个基于C# Winform开源免费的通用快速开发框架,内置完整的权限架构!

前言 今天大姚给大家分享一个基于C# Winform开源免费&#xff08;GPL-2.0开源协议&#xff09;的通用快速开发框架&#xff0c;内置完整的权限架构&#xff1a;WinformDevFramework。 项目介绍 WinformDevFramework是一个基于C# Winform开源免费&#xff08;GPL-2.0开源协议…...

2025年度福建省职业院校技能大赛高职组“信息安全管理与评估”赛项规程样题模块二

模块二 网络安全事件响应、数字取证调查、应用程序安全 竞赛项目赛题 本文件为信息安全管理与评估项目竞赛-第二阶段样题&#xff0c;内容包括&#xff1a;网络安全事件响应、数字取证调查。 本次比赛时间为90分钟。 介绍 竞赛有固定的开始和结束时间&#xff0c;参赛队伍必须…...

【朝夕教育】《鸿蒙原生应用开发从零基础到多实战》005-TypeScript 中的枚举

标题详情作者简介愚公搬代码头衔华为云特约编辑&#xff0c;华为云云享专家&#xff0c;华为开发者专家&#xff0c;华为产品云测专家&#xff0c;CSDN博客专家&#xff0c;CSDN商业化专家&#xff0c;阿里云专家博主&#xff0c;阿里云签约作者&#xff0c;腾讯云优秀博主&…...

使用create_sql_query_chain工具根据自然语言问题生成SQL查询,踩坑版

1. 开启调试模式 from langchain import debugdebug True # 启用调试模式说明&#xff1a; 这里从 langchain 库中导入了一个名为 debug 的变量&#xff08;或模块&#xff09;&#xff0c;然后将它设置为 True。这通常用来启用调试模式&#xff0c;方便开发者在程序运行时看…...

DeepSeek本地部署+自主开发对话Web应用

文章目录 引言前端部分核心页面DeepSeek.vueMyModal.vue 后端部分WebSocketConfig 配置类AbstractDeepSeekToolDeepSeekWebSocketHandler 数据库设计总结 引言 最近DeepSeep横空出世&#xff0c;在全球内掀起一股热潮&#xff0c;到处都是满血大模型接入的应用&#xff0c;但这…...

【Springboot】解决问题 o.s.web.servlet.PageNotFound : No mapping for *

使用 cursor 进行老项目更新为 springboot 的 web 项目&#xff0c;发生了奇怪的问题&#xff0c;就是 html 文件访问正常&#xff0c;但是静态文件就是 404 检查了各种配置&#xff0c;各种比较&#xff0c;各种调试&#xff0c;最后放弃时候&#xff0c;清理没用的配置文件&…...

微信小程序点击按钮,将图片下载到本地

前言&#xff1a; 最近在公司完成一个小程序的时候需要实现一个功能&#xff1a;点击按钮获取用户相册权限&#xff0c;将图片下载到用户本地相册&#xff0c;经过了好几次的尝试最终算是实现了。将总结的经验在这里分享给小伙伴们。 实现方式&#xff1a; //.wxml文件 <…...

解锁网络防御新思维:D3FEND 五大策略如何对抗 ATTCK

D3FEND 简介 背景介绍 2021年6月22日&#xff08;美国时间&#xff09;&#xff0c;美国MITRE公司正式发布了D3FEND——一个网络安全对策知识图谱。该项目由美国国家安全局&#xff08;NSA&#xff09;资助&#xff0c;并由MITRE的国家安全工程中心&#xff08;NSEC&#xff…...

架构案例:从初创互联网公司到分布式存储与反应式编程框架的架构设计

文章目录 引言一、初创互联网公司架构演化案例1. 万级日订单级别架构2. 十万级日订单级别架构3. 百万级日订单级别架构 二、分布式存储系统 Doris 架构案例三、反应式编程框架架构案例总结 引言 分布式架构 今天我们将探讨三种不同类型的架构案例&#xff0c;分别探讨 一个初…...

Redis数据结构-List列表

1.List列表 列表类型适用于存储多个有序的字符串&#xff08;这里的有序指的是强调数据排列顺序的重要&#xff0c;不是升序降序的意思&#xff09;&#xff0c;列表中的每个字符串称为元素&#xff08;element&#xff09;&#xff0c;一个列表最多可以存储2^32-1个元素。在R…...

开启AI短剧新纪元!SkyReels-V1/A1双剑合璧!昆仑万维开源首个面向AI短剧的视频生成模型

论文链接&#xff1a;https://arxiv.org/abs/2502.10841 项目链接&#xff1a;https://skyworkai.github.io/skyreels-a1.github.io/ Demo链接&#xff1a;https://www.skyreels.ai/ 开源地址&#xff1a;https://github.com/SkyworkAI/SkyReels-A1 https://github.com/Skywork…...

mac安装环境

minconda https://docs.anaconda.net.cn/miniconda/install/ 注意在下载下来应该有100多兆&#xff0c;太大了应该是完整版&#xff0c;我们不需要 jdk 镜像网站下载设置环境变量&#xff1a; 终端&#xff1a;sudo vim ~/.zshrc # JDK Config JAVA_HOME/Library/Java/Java…...