数组leetcode 2460

Java-04数组

tip:[start]程序 = 逻辑 + 数据,数组是存储数据的强而有力的手段。 —— 闫学灿tip:[end] 一维数组 数组的定义 数组的定义方式和变量类似。 java中数组的定义[]是写在数组名前面(与c++区分),开辟长度需要new,即面向对象。 public class Main { pu ......
数组 Java 04

Leetcode刷题day12-二叉树.前中后序遍历

递归法实现前.中.后序遍历 代码随想录 (programmercarl.com) 解题思路 前序遍历:头->左->右 中序遍历:左->头->右 后序遍历:左->右->头 递归法实现流程:1.定义递归函数;2.寻找递归终止条件;3.设计单层递归模块 class Solution(): def __in ......
Leetcode day 12

树状数组

树状数组所维护的数组记为\(a\),\(n\)表示\(a\)中元素个数,\(lowbit(i)\)表示最低位\(1\)和后面所有\(0\)组成的数,\(c[i]\)表示\(a\)区间\([i - lowbit(i) + 1, i]\)的和。 \(add(k, x)\):单点修改,表示\(a[k]=a ......
数组

Java数组

免责声明:java基础资料均来自于韩顺平老师的《循序渐进学Java零基础》教案,具体视频内容可以去B站观看,这些资料仅用于学习交流,不得转载用于商业活动 1.数组 数组可用存放多个同一类型的数据,数组也是一种数据类型,是引用类型 1.1 一维数组 1.1.1 使用方式1-动态初始化 语法:数据类型 ......
数组 Java

linux 中 数组的常见操作

001、创建数组(三种方法)(下标连续数组和下标不连续数组) a、 002、访问数组(访问全部元素;访问单个元素) 003、遍历数组(利用循环实现;for;while) 004、输出数组的长度(下标连续和下标不连续) 005、输出数组的下标(下标连续和下标不连续) 006、输出数组中每个元素的长度 ......
数组 常见 linux

Leetcode刷题day11-栈.滑窗最大值.出现次数前K的元素

239.滑动窗口最大值 239. 滑动窗口最大值 - 力扣(LeetCode) 给你一个整数数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。 返回 滑动窗口中的最大值 。 示例 1: 输入:nums = ......
最大值 Leetcode 元素 次数 day

[LeetCode Hot 100] LeetCode25. K个一组翻转链表

题目描述 思路: 判断链表中是否足够k个元素 再将这k个元素内部翻转一下 将前后端点连接的指针变化一下 方法一: /** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next ......
LeetCode Hot 100 25

[LeetCode Hot 100] LeetCode148. 排序链表

题目描述 思路一:堆排序、小顶堆 定义一个最小堆 将链表的所有节点放入一个最小堆中 直接用队列弹出的最小值依次覆盖掉原链表的值 方法一: /** * Definition for singly-linked list. * public class ListNode { * int val; * L ......
LeetCode Hot 100 148

[LeetCode Hot 100] LeetCode138. 随机链表的复制

题目描述 思路一:添加"小弟" 根据遍历到的原节点创建对应的新节点,每个新创建的节点是在原节点后面。 原节点i的随机指针(如果有的话),指向的是原节点j,那么新节点i的随机指针,指向的是原节点j的next 最后将两个链表分开,再返回新链表就可以 思路二:使用哈希表 首先创建一个哈希表,再遍历原链表, ......
LeetCode Hot 100 138

[LeetCode Hot 100] LeetCode24. 两两交换链表中的节点

题目描述 思路: 创建dummy节点,令dummy.next = head。令cur表示当前到达的节点,初始时cur = dummy。每次需要交换cur后面的两个节点。 如果cur的后面没有节点或者只有一个节点,则没有更多的节点需要交换,因此结束交换。否则,获得cur后面的两个节点node1和nod ......
LeetCode 节点 Hot 100 24

88. 合并两个有序数组

1.题目介绍 给你两个按 非递减顺序 排列的整数数组 \(nums1\) 和 \(nums2\),另有两个整数 \(m\) 和 \(n\) ,分别表示 \(nums1\) 和 \(nums2\) 中的元素数目。 请你 合并 \(nums2\) 到 \(nums1\) 中,使合并后的数组同样按 非递减 ......
数组 两个 88

LeetCode-总入口

LeetCode刷题整理 LeetCode-1-二叉树 LeetCode-2-动态规划 LeetCode-3-二分查找 LeetCode-4-BFS/DFS/回溯 LeetCode-5-双指针 LeetCode-10-位操作 10大排序算法+topK 链表操作 2021秋招-数据结构-栈、队列、数组 ......
LeetCode 入口

二维树状数组

见一本通P211 讲一下\(c_{i,j}\)表示什么,见下图 代表右上角圈起来的那一块的总和 于是再去理解书上的修改和求和代码即可 ......
数组

列表 切片 动态数组

切片(slice)是一种动态数组的抽象。切片提供了对数组的一段连续片段的引用,并且可以动态增长或缩小。与数组不同,切片的长度是可变的,可以根据需要进行调整,而且切片是引用类型 创建空切片 var numbers []int 创建切片2 slice1 := []int{1, 2, 3, 4, 5} p ......
数组 动态

【算法】【线性表】两个排序数组的中位数

1 题目 两个排序的数组A和B分别含有m和n个数,找到两个排序数组的中位数,要求时间复杂度应为 O(log(m + n))。 中位数的定义: 这里的中位数等同于数学定义里的中位数。 中位数是排序后数组的中间值。 如果有数组中有n个数且n是奇数,则中位数为 A((n-1)/2)。 如果有数组中有n个数 ......
中位数 数组 线性 算法 两个

[LeetCode19-链表-中等] 删除链表的倒数第N个节点

这道题也是关于链表的题目,题目原意是这样的,给你一个链表,删除这个链表的倒数第n个结点,并返回头结点(也就是其余的结点组成的新链表) 比如 1->3->5->7->9 n =2 也就是删除倒数第2个结点,值为7的结点。返回头结点为 1->3->5->9 ......
节点 LeetCode 19

[ LeetCode ] 67. Add Binary

题目 Given two binary strings a and b, return their sum as a binary string. 思考 题外话:根据LeetCode premium的说法,这题是no.4最常被Facebook面试问到的题目 这题是二进制相加的问题 什么是二进制 二进 ......
LeetCode Binary Add 67

[LeetCode Hot 100] LeetCode155. 最小栈

题目描述 思路一:使用辅助栈 定义一个[数据栈]来支持push、pop、top操作 定义一个[辅助栈],其栈顶为当前的最小值,以支持常数时间复杂度的getMin操作 思路二:使用ArrayDeque 栈元素中除了保存当前值之外,额外保存当前最小值 使用静态内部类 方法一:对应思路一 class Mi ......
LeetCode Hot 100 155

逆序对——权值树状数组+离散化

给定一个长度为 n 的整数数列,请你计算数列中的逆序对的数量。每个数字不超过1e9。 int n, m; int a[N]; int tr[N]; vector<int>lan; int lowbit(int x){ return x&(-x); } void discrete() { sort(l ......
逆序 数组

Leetcode刷题day9-栈.队列-栈转队列.队列转栈

232.用栈实现队列 232. 用栈实现队列 - 力扣(LeetCode) 请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作(push、pop、peek、empty): 实现 MyQueue 类: void push(int x) 将元素 x 推到队列的末尾 int pop()  ......
队列 Leetcode day9 day

Python NumPy 合并数组和分割数组

在 Python 的 NumPy 库中,合并和分割数组是两种常用的操作,用于重组和分解数据集。将多个数据集合并为一个数据集,方便进行后续的处理。将数据集拆分为多个子数据集,用于并行处理或分布式处理。将数据集按指定条件进行分组,方便进行分析。 1、合并数组 合并数组是一种常见操作,允许你将多个数组组合 ......
数组 Python NumPy

Java第六课_二维数组

1.二维数组 增强for循环 // 增强for循环 : for(数据类型 元素名 : 数组/集合){} // 注意 : 增强的for循环中是没有索引值 // 属于是针对数组的简介写法 int[] a = {1,2,3}; for (int date : a) { // 只需数据类型即可,无需[] S ......
数组 Java

【算法】【线性表】搜索旋转排序数组(有重复数据)

1 题目 跟进“搜索旋转排序数组”,假如有重复元素又将如何?是否会影响运行时间复杂度?如何影响?为何会影响?写出一个函数判断给定的目标值是否出现在数组中。 样例 1: 输入: A = [] target = 1 输出: false 解释:数组为空,1不在数组中。 样例 2: 输入: A = [3,4 ......
数组 线性 算法 数据

2023-12-09:用go语言,给你两个整数数组 arr1 和 arr2, 返回使 arr1 严格递增所需要的最小「操作」数(可能为 0)。 每一步「操作」中,你可以分别从 arr1 和 arr2

2023-12-09:用go语言,给你两个整数数组 arr1 和 arr2, 返回使 arr1 严格递增所需要的最小「操作」数(可能为 0)。 每一步「操作」中,你可以分别从 arr1 和 arr2 中各选出一个索引, 分别为 i 和 j,0 <= i < arr1.length 和 0 <= j ......
arr arr1 整数 数组 arr2

【JavaSE】数据结构(栈、队列、数组、链表)

什么是数据结构? 数据结构是计算机底层存储、组织数据的方式,是指数据相互之间是什么方式排列在一起的 常见的数据结构 栈、队列、数组、链表 二叉树、二叉查找树、平衡二叉树、红黑树 哈希表 栈 特点:先进后出 队列 特点:先进先出 数组 特点:有索引,内存连续 优点:查询速度快O(1) 缺点:增删速度慢 ......
数据结构 队列 数组 结构 数据

[LeetCode Hot 100] LeetCode20. 有效的括号

题目描述 思路: 栈的经典应用。 注意下遇到右括号的代码,即边界情况: // 遇到右括号,则进行括号匹配 if (!stack.isEmpty() && stack.peek() == match(c)) { // 如果匹配则直接弹出栈顶元素 stack.pop(); } else { // 如果不 ......
LeetCode 括号 Hot 100 20

Python NumPy 数组形状操作

1、获取数组的形状 1、获取数组的形状 要获取数组的形状,可以使用 shape 属性。 文档:Python numpy.shape函数方法的使用 2、改变数组形状 要改变数组的形状,可以使用 reshape() 方法。 文档:Python numpy.reshape函数方法的使用 3、改变数组的大小 ......
数组 形状 Python NumPy

数组

在Go语言中,数组(Array)是一种固定长度的、相同数据类型的元素序列。数组的长度是数组类型的一部分,这意味着一旦数组被声明,其长度不能更改。数组提供了对元素的快速访问,是一种简单而基本的数据结构。 声明数组 var arrayName [length]elementType var number ......
数组

[LeetCode Hot 100] LeetCode215. 数组中的第K个最大元素

题目描述 思路:小顶堆 维护一个大小为K的小顶堆 遍历所有元素: 如果当前堆中元素个数小于K,则将元素添加到堆中 如果当前堆中元素个数等于K,则判断第K + 1 方法一: class Solution { public int findKthLargest(int[] nums, int k) { ......
LeetCode 数组 元素 Hot 100

[LeetCode Hot 100] LeetCode295. 数据流的中位数

题目描述 思路:一个大根堆+一个小根堆+保持数量 一个大根堆用来记录数轴左边的数值 一个小根堆用来记录数轴右边的数值 大根堆的容量要么等于小根堆的容量(此时是偶数个有序整数列表),要么大根堆的容量比小根堆的容量大1(此时是奇数个有序整数列表) 如果数量不符合上述条件,则将超过容量的那个堆的堆顶元素插 ......
LeetCode 中位数 数据流 数据 Hot
共4200篇  :11/140页 首页上一页11下一页尾页