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;
};

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

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

相关文章

C#贪心算法

贪心算法&#xff1a;生活与代码中的 “最优选择大师” 在生活里&#xff0c;我们常常面临各种选择&#xff0c;都希望能做出最有利的决策。比如在超市大促销时&#xff0c;面对琳琅满目的商品&#xff0c;你总想用有限的预算买到价值最高的东西。贪心算法&#xff0c;就像是一…

【JAVA SE基础】抽象类和接口

目录 一、前言 二、抽象类 2.1 抽象类的概念 2.2 抽象类语法 2.3 抽象类特性 2.4 抽象类的作用 三、接口 3.1 什么是接口 3.2 语法规则 3.3 接口使用 3.4 接口特性 3.5 实现多接口 3.6 接口间的继承 四、Object类 4.1 获取对象信息&#xff08; toString() &…

查找Excel包含关键字的行(の几种简单快速方法)

需求&#xff1a;数据在后缀为xlsx的Excel的sheet1中且量比较大&#xff0c;比如几十万行几百列&#xff1b;想查找一个关键字所在的行,比如"全网首发"&#xff1b; 情况①知道关键字在哪一列 情况②不确定在哪一列&#xff0c;很多列相似又不同&#xff0c;本文演…

网络运维学习笔记(DeepSeek优化版)009网工初级(HCIA-Datacom与CCNA-EI)路由理论基础与静态路由

文章目录 路由理论基础核心概念路由表六要素路由选路原则加表规则选路优先级 协议与参数常见协议号路由协议优先级对比 网络架构基础AS&#xff08;autonomous system&#xff0c;自治系统&#xff09;路由分类 静态路由(static routing)实验拓扑思科配置示例华为配置示例 典型…

为什么深度学习选择Tensor而非NumPy数组?核心优势深度解析

简短总结&#xff1a; 支持 GPU 加速&#xff1a;Tensor 提供对 GPU 的原生支持&#xff0c;能够有效加速计算&#xff0c;而 NumPy 则通常只能在 CPU 上运行。支持自动求导&#xff1a;深度学习模型的训练依赖于参数的优化&#xff0c;而 Tensor 提供了自动求导功能&#xff…

Python 绘制迷宫游戏,自带最优解路线

1、需要安装pygame 2、上下左右移动&#xff0c;空格实现物体所在位置到终点的路线&#xff0c;会有虚线绘制。 import pygame import random import math# 迷宫单元格类 class Cell:def __init__(self, x, y):self.x xself.y yself.walls {top: True, right: True, botto…

Qt for Android下QMessageBox背景黑色、文字点击闪烁

最近在基于Qt开发安卓应用的时候,在红米平板上默认QMessageBox出现之后,背景黑色,并且点击提示文字会出现闪烁,影响用户体验。 问题分析 1、设置QMessageBox样式,设置背景色、文字颜色,如下所示: QMessageBox {background: white;color: white; } 尝试之后,问题仍存…

基于Springboot博物馆文博资源库系统【附源码】

基于Springboot博物馆文博资源库系统 效果如下&#xff1a; 系统登陆页面 文物信息管理页面 流动申请页面 文物报修页面 个人信息页面 文物保修管理页面 系统主页面 文物类型页面 研究背景 随着信息技术的飞速发展&#xff0c;博物馆文博资源的管理与利用日益受到重视。传统…

eNSP中AR2220、AR201、AR1220、AR2240、AR3260、Router、NE40E、NE5000E、NE9000、CX路由器学习笔记

eNSP中常见华为路由器型号的接口特性详解及横向对比&#xff0c;重点关注接口类型、扩展能力和适用场景&#xff1a; 缩写解释&#xff1a; LPU&#xff1a;Line Processing Unit&#xff08;线路处理单元&#xff09; SPU&#xff1a;Service Processing Unit&#xff08;业务…

【考试大纲】初级信息系统运行管理员考试大纲

目录 引言一、考试要求1、 考试说明2、 考试要求3、 本考试设置的科目包括:二、考试范围考试科目1:信息系统基础知识(初级)考试科目2:信息系统运行管理(应用技术)引言 最新的信息系统运行管理员考试大纲出版于 2018 年 9 月,本考试大纲基于此版本整理。 一、考试要求…

基于单片机的智能扫地机器人

1 电路设计 1.1 电源电路 本电源采用两块LM7805作为稳压电源&#xff0c;一块为控制电路和传感器电路供电&#xff0c;另一块单独为电机供电。分开供电这样做的好处&#xff0c;有利于减小干扰&#xff0c;提高系统稳定性。 LM7805是常用的三端稳压器件&#xff0c;顾名思义0…

传输层协议TCP

TCP全称为 传输控制协议(Transmission Control Protocol)&#xff0c;就是要对数据的传输进行一个详细的控制。 TCP协议段格式 源端口&#xff1a;发送方的端口号&#xff0c;用来标识发送端的应用程序或进程。 目标端口&#xff1a;接收方的端口号&#xff0c;用来标识接收端…

ST-LINK端口连接失败,启动GDB server失败的问题处理方法,有效

目录 1. 问题描述2. 解决办法2.1 后台关闭2.2 后台关闭无法找到ST进程或者关闭后未解决 1. 问题描述 报错&#xff1a; Failed to bind to port 61235, error code -1: No error Failure starting SWV server on TCP port: 61235 Failed to bind to port 61234, error code -1…

OpenCV计算摄影学(3)CUDA 图像去噪函数fastNlMeansDenoising()

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 使用非局部均值去噪算法&#xff08;Non-local Means Denoising algorithm&#xff09;执行图像去噪&#xff0c;该算法来源于 http://www.ipol.…

Windows逆向工程入门之MASM字符处理机制

公开视频 -> 链接点击跳转公开课程博客首页 -> ​​​链接点击跳转博客主页 目录 一、MASM字符编码体系深度解析 1. 多层编码支持架构 编码转换关键技术&#xff1a; 2. 字符串存储优化策略 内存优化特征&#xff1a; 二、逆向工程中的字符串特征识别 1. 字符串解…

Linux上用C++和GCC开发程序实现两个不同MySQL实例下单个Schema稳定高效的数据迁移到其它MySQL实例

设计一个在Linux上运行的GCC C程序&#xff0c;同时连接三个不同的MySQL实例&#xff0c;其中两个实例中分别有两个Schema的表结构分别与第三实例中两个Schema个结构完全相同&#xff0c;同时复制两个实例中两个Schema里的所有表的数据到第三个实例中两个Schema里&#xff0c;使…

如何评估所选择的PHP后端框架的性能?

大家在选择PHP后端框架的时候&#xff0c;如果想评估其性能如何&#xff0c;能不能扛得住你的项目&#xff1f;可以根据以下几点进行分析&#xff0c;帮助大家选择到更符合自己心目中的PHP后端框架。 1. 基准测试 基准测试是评估框架性能的基础方法&#xff0c;主要通过模拟高…

P8649 [蓝桥杯 2017 省 B] k 倍区间--前缀和--同余定理【蓝桥杯简单题-必开long long】

P8649 [蓝桥杯 2017 省 B] k 倍区间--前缀和--同余定理 题目 分析代码 还有一件事【老爹音】 题目 分析 首先&#xff0c;看到”连续子序列求和”这一要求时&#xff0c;我们果断选择前缀和解答。 接着就要用到一个非常巧妙的“同余定理”——如果 sum[j] % K sum[i] % K&am…

如何免费使用稳定的deepseek

0、背景&#xff1a; 在AI辅助工作中&#xff0c;除了使用cursor做编程外&#xff0c;使用deepseek R1进行问题分析、数据分析、代码分析效果非常好。现在我经常会去拿行业信息、遇到的问题等去咨询R1&#xff0c;也给了自己不少启示。但是由于官网稳定性很差&#xff0c;很多…

拉链表介绍

拉链表 是处理 缓慢变化维&#xff08;SCD&#xff09; 的一种常用方法&#xff0c;特别适用于需要保留历史记录的场景。以下是拉链表的详细说明及实现方法&#xff1a; 1. 什么是拉链表&#xff1f; 拉链表是一种用于记录维度数据历史变化的表结构&#xff0c;通过 开始时间 …