leetcode剑指offer75题

news2024/11/17 17:51:13

1 替换空格

在这里插入图片描述

var replaceSpace = function(s) {
    const str = s.split(' ');
    return str.join('%20')
};

2 左旋转字符串

在这里插入图片描述

var reverseLeftWords = function(s, n) {
    const s1 = s.slice(n)
    const s2 = s.slice(0,n)
    return s1+s2
};

3 表示数值的字符串

在这里插入图片描述在这里插入图片描述

//\d+ 匹配整数 1次或多次
//(\.\d*)? 满足小数条件12 ?匹配0次或1次, 0次即整数 1次即小数
// \.\d+ 满足小数条件3

var isNumber = function(s) {
    const str = s.trim();
    const reg = /^[\+\-]?((\d+(\.\d*)?)|(\.\d+))(e[\+\-]?\d+)?$/i;
    return reg.test(str)
};

4 把字符串转换成整数

在这里插入图片描述

var strToInt = function(str) {
    //首先判断开头是不是空白字符
    if(str.match(/[^\s]|[^\d]/)){
        const [INT_MIN, INT_MAX] = [Math.pow(-2,31),Math.pow(2,31)-1]
        const s = str.trim();
        const res = s.match(/^[\+\-]?\d+/g);
        if(res > INT_MAX) return INT_MAX;
        if (res < INT_MIN) return  INT_MIN;
        return res;
    } else {
        return 0;
    }
};

5 从尾到头打印链表

在这里插入图片描述

var reversePrint = function(head) {
    const arr = []
    while(head?.next) {
        arr.push(head.val);
        head = head.next
    }
    if(head?.val || head?.val===0) arr.push(head.val);
    return arr.reverse()
};

6 反转链表

在这里插入图片描述

var reverseList = function(head) {
    let prev = null
    let curr = head
    while(curr) {
        const next  = curr.next
        curr.next = prev
        prev=curr
        curr = next
    }
    return prev
};

7 复杂链表的复制

在这里插入图片描述

var copyRandomList = function(head) {
    if(!head) return null
    const map = new Map()
    let prev = head
    //创建一个新的节点
    while(prev){
        map.set(prev, new Node(prev.val))
        prev = prev.next
    }
    map.set(null,null)
    prev = head
    //将各个链表节点连接起来
    while(prev) {
        map.get(prev).next = map.get(prev.next)
        map.get(prev).random = map.get(prev.random)
        prev = prev.next
    }
    return map.get(head)
};

8 删除链表的节点

在这里插入图片描述

var deleteNode = function(head, val) {
    if(!head) return null
    let newNode = new ListNode(0,head)
    let prev = newNode
    let curr = head
    while(curr){
        if(curr.val === val) {
            prev.next = curr.next
        } else {
            prev = curr
        }
        curr = curr.next
    }
    return newNode.next
};

9 链表中倒数第k个节点

在这里插入图片描述

 let slow = head
    let fast = slow
    while(k--){
        fast = fast.next
    }
    if(!fast) return slow
    if(!fast.next) return slow.next
    while(fast?.next){
        fast = fast.next
        slow = slow.next
    }
    return slow.next

10 合并两个排序的链表

在这里插入图片描述

let prev = new ListNode(null)
    let curr = prev
    while(l1 && l2){
        if(l1?.val >= l2?.val){
            prev.next = l2
            l2 = l2?.next
            prev = prev.next
        } else {
            prev.next = l1
            l1 = l1?.next
            prev = prev.next
        }
    }
    if (l1) prev.next = l1
    if (l2) prev.next = l2
    return curr.next

11 两个链表的第一个公共节点

在这里插入图片描述

var getIntersectionNode = function(headA, headB) {
    let prevA = headA
    let prevB = headB
    while(prevA !== prevB) {
        prevA = prevA ? prevA.next : headB
        prevB = prevB ? prevB.next : headA
    }
    return prevA
};

12 调整数组顺序使奇数位于偶数前面

在这里插入图片描述

var exchange = function(nums) {
    const arr = []
    nums.forEach((num)=>{
        if(num%2 === 1) {
            arr.unshift(num)
        } else {
            arr.push(num)
        }
    })
    return arr
};

13 和为s的两个数字

在这里插入图片描述

var twoSum = function(nums, target) {
    let l = 0 
    let r = nums.length-1
    while(l!==r){
        const res = nums[l]+nums[r]
        if(res > target){
            r--
        } else if (res < target) {
            l++
        } else {
            return [nums[l],nums[r]]
        }
    }
};

14 翻转单词顺序

在这里插入图片描述

var reverseWords = function(s) {
    const arr = s.trim().split(' ').filter(item=>item)
    return arr.reverse().join(' ')
};

15 用两个栈实现队列

在这里插入图片描述

var CQueue = function() {
    this.stackA = []
    this.stackB = []
};

/** 
 * @param {number} value
 * @return {void}
 */
CQueue.prototype.appendTail = function(value) {
    this.stackA.push(value)
};

/**
 * @return {number}
 */
CQueue.prototype.deleteHead = function() {
    if(this.stackB.length){
        return this.stackB.pop()
    } else {
        while(this.stackA.length) {
            this.stackB.push(this.stackA.pop())
        }
        if(!this.stackB.length){
            return -1
        } else {
            return this.stackB.pop()
        }
    }
};

16 包含min函数的栈

在这里插入图片描述

var MinStack = function() {
    this.stack = []
};

/** 
 * @param {number} x
 * @return {void}
 */
MinStack.prototype.push = function(x) {
    this.stack.push(x)
};

/**
 * @return {void}
 */
MinStack.prototype.pop = function() {
    this.stack.pop()
};

/**
 * @return {number}
 */
MinStack.prototype.top = function() {
    return this.stack[this.stack.length-1]
};

/**
 * @return {number}
 */
MinStack.prototype.min = function() {
    let min = Infinity
    this.stack.forEach((num)=>{
        if(num<min){
            min = num
        }
    })
    return min
};

17 滑动窗口的最大值

在这里插入图片描述

const maxSlidingWindow = (nums,k) => {
	const queue = []
	const res = []
	let len = nums.length
	for(let i = 0; i < len; i++){
		while(queue.length && nums[queue.at(-1)] <= nums[i]){
			queue.pop()
		}
		queue.push(i)
		if(queue.length && queue[0] = i-k) queue.shift()
		if(i>= k-1){
			res.push(nums[queue[0]])
		}
	}
}

18 队列的最大值

在这里插入图片描述

var MaxQueue = function() {
    this.stack = []
    this.max = -Infinity
};

/**
 * @return {number}
 */
MaxQueue.prototype.max_value = function() {
    if(this.stack.length) return this.max
    return -1
};

/** 
 * @param {number} value
 * @return {void}
 */
MaxQueue.prototype.push_back = function(value) {
    this.stack.push(value)
    if (value > this.max) this.max = value
};

/**
 * @return {number}
 */
MaxQueue.prototype.pop_front = function() {
    if (this.stack.length){
        const res = this.stack.shift()
        if(res === this.max) {
            this.max = Math.max(...this.stack)
        }
        return res
    }  
    return -1
};

19 顺时针打印矩阵

在这里插入图片描述

var spiralOrder = function(matrix) {
    if(!matrix.length) return []
    let row = matrix.length
    let col  = matrix[0].length
    const res = []
    size = row*col
    let t = 0, r = col-1, b = row-1, l =0
    while(res.length!==size) {
        //从左往右
        for(let i = l;i<=r;i++) res.push(matrix[t][i])
        t++
		//从左到右可能便利完的矩阵
		//[[1,2,3],[4,5,6],[7,8,9]]

        //从上往下
        for(let i = t; i<=b;i++) res.push(matrix[i][r])
        r--
        //从上到下可能遍历完的矩阵
		//[[7],[8],[9]]
        //到这里可能就遍历完了
        if(res.length===size) break

        //从左往右
        for(let i = r; i>=l; i--) res.push(matrix[b][i])
        b--;
        //从下往上
        for(let i = b;i>=t; i--) res.push(matrix[i][l])
        l++
    } 
    return res
};

20 栈的压入、弹出序列

在这里插入图片描述

var validateStackSequences = function(pushed, popped) {
    let stack = []
    let i = 0
    //模拟入栈出栈
    for(item of pushed) {
        stack.push(item)
        while(stack.length && stack.at(-1) == popped[i]){
            stack.pop()
            i++
        }
    }
    return !stack.length
};

21 数组中的重复数字

在这里插入图片描述

var findRepeatNumber = function(nums) {
    let map = new Map()
    let res
    for(num of nums){
        if (map.get(num)){
            res = num
            break
        } 
        map.set(num,1)
    }
    return res
};

22 在排序数组中查找数字I

在这里插入图片描述

//法一
var search = function(nums, target) {
    let res = 0
    for(num of nums){
        if(num===target)res++
    }
    return res
};

//法二
var search = function(nums, target) {
    return nums.filter(item => item === target).length
};

23 0~n-1中缺失的数字

在这里插入图片描述

//等差数列前n项和
var missingNumber = function(nums) {
    const n = nums.length+1
    let total = Math.floor(n*(n-1)/2)
    let res = nums.reduce((prev,curr) => prev+curr, 0)
    return total - res
};

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

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

相关文章

【腾讯云 Cloud studio 实战训练营】真正做到让你的开发成本只在编码

文章目录 写在前面CODINGCloud studio工具在线编码运行项目代码上传Cloud Studio 开发贪吃蛇写在最后 写在前面 期待已久的体验活动终于来了&#xff0c;Clound Studio用了才知道有多爽&#xff0c;Cloud Studio 是基于浏览器的集成式开发环境 (IDE)&#xff0c;为开发者提供了…

第二课:数据类型与变量

一. 数据类型 整型 byte short int long 小数 float double 字符 char 布尔 boolean 1.不论在16位&#xff0c;32位还是64位系统&#xff0c;int都占用4个字节&#xff0c;long都占用8个字节 &#x1f446;可移植性&#xff0c;可以跨平台运行&#xf…

【黑马头条之redis实现延迟任务】

本笔记内容为黑马头条项目的延迟任务精准发布文章部分 目录 一、实现思路 二、延迟任务服务实现 1、搭建heima-leadnews-schedule模块 2、数据库准备 3、安装redis 4、项目集成redis 5、添加任务 6、取消任务 7、消费任务 8、未来数据定时刷新 1.reids key值匹配 …

“智能算式批改系统”开发与部署优化

“智能算式批改系统”开发与部署优化 摘要 本次大作业搭建并实现了“智能算式批改系统”的开发与部署优化。“智能算式批改系统”是一款集yolo目标检测、paddleocr识别和四则运算判别算法的智能批改系统。该系统能够对上传包含四则运算题的页面进行批改&#xff0c;包括识别出…

【Docker】Docker安装Kibana服务

文章目录 1. 什么是Kibana2. Docker安装Kibana2.1. 前提2.2. 安装Kibana Docker安装MySQL、Redis、RabbitMQ、Elasticsearch、Nacos等常见服务全套&#xff08;质量有保证&#xff0c;内容详情&#xff09; 1. 什么是Kibana Kibana 是一款适用于Elasticsearch的数据可视化和管…

PyTorch深度学习实战(7)——批大小对神经网络训练的影响

PyTorch深度学习实战&#xff08;7&#xff09;——批大小对神经网络性能的影响 0. 前言1. 批处理概念2. 批处理的优势3. 批大小对神经网络性能的影响3.1 批大小为 323.2 批大小为 30,000 小结系列链接 0. 前言 在神经网络中&#xff0c;批( batch )是指一次输入网络进行训练或…

微服务体系<2> ribbon

1. 什么是负载均衡 比如说像这样 一个请求打在了nginx上 基于nginx进行负载分流 这就是负载均衡但是负载均衡分 服务端负载均衡和客户端负载均衡 客户端负载均衡 我user 从注册中心拉取服务 拉取order列表&#xff0c;然后发起getOne()调用 这就是客户端负载均衡 特点就是我…

【echarts】用js与echarts数据图表化,折线图、折线图堆叠、柱状图、折柱混合、环形图

echarts 是一个基于 JavaScript 的开源可视化库&#xff0c;用于构建交互式和自定义的图表&#xff0c;使数据更加直观和易于理解&#xff0c;由百度开发并于2018年捐赠给 Apache 软件基金会&#xff0c;后来改名为Apache ECharts 类似的还有Chart.js Chart.js地址&#xff1…

从此告别涂硅脂 利民推出新款CPU固态导热硅脂片:一片26.9元

利民(Thermalright)近日推出了新款Heilos CPU固态导热硅脂片&#xff0c;其中Intel版为26.9元&#xff0c;AMD版售价29.9元。 以往向CPU上涂硅脂&#xff0c;需要先挤一粒绿豆大小的硅脂&#xff0c;然后用塑料片涂匀&#xff0c;操作和清理对新手都极不友好。 该固态导热硅脂片…

string【2】模拟实现string类

string模拟实现 引言&#xff08;实现概述&#xff09;string类方法实现默认成员函数构造函数拷贝构造赋值运算符重载析构函数 迭代器beginend 容量size、capacity、emptyreserveresize 访问元素operator[] 修改insert插入字符插入字符串 appendpush_backoperatoreraseclearswa…

Python web实战 | 使用 Flask 实现 Web Socket 聊天室

概要 今天我们学习如何使用 Python 实现 Web Socket&#xff0c;并实现一个实时聊天室的功能。本文的技术栈包括 Python、Flask、Socket.IO 和 HTML/CSS/JavaScript。 什么是 Web Socket&#xff1f; Web Socket 是一种在单个 TCP 连接上进行全双工通信的协议。它是 HTML5 中的…

SAMBA 文件分享相关 笔记

目标说明 在Linux 安装Samba&#xff0c;然后在Windows端映射为网络硬盘 流程 Linux 端命令 apt install samba -y 默认情况下软件会询问是否迁移系统网络设置以搭建协议&#xff0c;选择迁移即可修改配置文件 vim /etc/samba/smb.conf Samba 的配置文件中会带一个名为 prin…

【Mybatis】Mybatis架构简介

文章目录 1.整体架构图2. 基础支撑层2.1 类型转换模块2.2 日志模块2.3 反射工具模块2.4 Binding 模块2.5 数据源模块2.6缓存模块2.7 解析器模块2.8 事务管理模块 3. 核心处理层3.1 配置解析3.2 SQL 解析与 scripting 模块3.3 SQL 执行3.4 插件 4. 接口层 1.整体架构图 MyBatis…

第5集丨webpack 江湖 —— 项目发布 和 source map

目录 一、webpack项目发布1.1 新增发布(build)命令1.2 优化js和图片文件的存放路径1.3 执行1.4 效果 二、clean-webpack-plugin插件2.1 安装2.2 配置2.3 执行 三、source map3.1 配置3.2 生成的source map文件 四、定义符4.1 配置4.2 使用 五、工程附件汇总5.1 webpack.config.…

大麦订单一键生成 仿大麦订单生成

后台一键生成链接&#xff0c;独立后台管理 教程&#xff1a;修改数据库config/Conn 不会可以看源码里有教程 下载程序&#xff1a;https://pan.baidu.com/s/16lN3gvRIZm7pqhvVMYYecQ?pwd6zw3

强化学习(EfficientZero)(应用于图像和声音)

目录 摘要 1.背景介绍 2.MCTS&#xff08;蒙特卡洛树搜索&#xff09;&#xff08;推理类模型&#xff0c;棋类效果应用好&#xff0c;控制好像也不错&#xff09; 3.MUZERO 4.EfficientZero&#xff08;基于MUZERO&#xff09; 展望 参考文献 摘要 在文中&#xff0c;基于…

【雕爷学编程】MicroPython动手做(20)——掌控板之三轴加速度5

知识点&#xff1a;什么是掌控板&#xff1f; 掌控板是一块普及STEAM创客教育、人工智能教育、机器人编程教育的开源智能硬件。它集成ESP-32高性能双核芯片&#xff0c;支持WiFi和蓝牙双模通信&#xff0c;可作为物联网节点&#xff0c;实现物联网应用。同时掌控板上集成了OLED…

数学建模 好文章和资源推荐

数学建模入门篇(0基础必看&#xff0c;全是自己的经验) 【竞赛|数学建模】Part 1&#xff1a;什么是数学建模和各模块介绍 0基础小白&#xff0c;如何入门数学建模&#xff1f; 数学建模入门篇(0基础必看&#xff0c;全是自己的经验) 什么是数学建模 重申了一下题目&#xff…

基于SpringBoot+Vue的地方废物回收机构管理系统设计与实现(源码+LW+部署文档等)

博主介绍&#xff1a; 大家好&#xff0c;我是一名在Java圈混迹十余年的程序员&#xff0c;精通Java编程语言&#xff0c;同时也熟练掌握微信小程序、Python和Android等技术&#xff0c;能够为大家提供全方位的技术支持和交流。 我擅长在JavaWeb、SSH、SSM、SpringBoot等框架…

并发编程——线程池

1.概述 如果并发的线程过多&#xff0c;而且执行的时间都非常短&#xff0c;如果这样&#xff0c;每次都要创建线程就会大大降低效率&#xff0c;我们可以通过线程池来解决&#xff0c;JDK5增加了内置线程池ThreadPollExecutor。 2.线程池的优点 1.重复利用&#xff0c;降低…