| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 数据结构之数组练习 -> 正文阅读 |
|
[数据结构与算法]数据结构之数组练习 |
1.leetcode704给定一个?n?个元素有序的(升序)整型数组?nums 和一个目标值?target ?,写一个函数搜索?nums?中的 target,如果目标值存在返回下标,否则返回 -1。 题解:升序 数组 方法:? ?二分法 思想:定义查找范围[left,right],初始查找范围为mid((left+right)/2) 比较nums[mid]和target的值: 如果nums[i]=target,则下标i即为要寻找的下标; 如果nums[列]> target,则target 只可能在下标i的左侧;
注意: (1)设立区间为[left, right],终止条件为left>rigth 2.leetcode 27移除元素给你一个数组 nums?和一个值 val,你需要 原地 移除所有数值等于?val?的元素,并返回移除后数组的新长度。 不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并原地修改输入数组。 元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。 示例 1: 给定 nums = [3,2,2,3], val = 3, 函数应该返回新的长度 2, 并且 nums 中的前两个元素均为 2。 你不需要考虑数组中超出新长度后面的元素。 示例?2: 给定 nums = [0,1,2,2,3,0,4,2], val = 2, 函数应该返回新的长度 5, 并且 nums 中的前五个元素为 0, 1, 3, 0, 4。 思路:要知道数组的元素在内存地址中是连续的,不能单独删除数组中的某个元素,只能覆盖。 方法:双指针
solwindex:用来覆盖 fastindex:来找删除元素++ 3.有序数组的平方给你一个按?非递减顺序?排序的整数数组 A,返回?每个数字的平方?组成的新数组,要求也按?非递减顺序?排序。 数组其实是有序的, 只不过负数平方之后可能成为最大数了。 那么数组平方的最大值就在数组的两端,不是最左边就是最右边,不可能是中间。 此时可以考虑双指针法了, i指向起始位置(负数),j指向终止位置(正数)。 定义一个新数组result,和A数组一样的大小,让k指向result数组终止位置。 如果 如果
4.长度最小的子数组给定一个含有?n?个正整数的数组和一个正整数 target 。 找出该数组中满足其和 ≥ target 的长度最小的 连续子数组?[numsl, numsl+1, ..., numsr-1, numsr] ,并返回其长度。如果不存在符合条件的子数组,返回 0 。 方法:滑动窗口法 就是不断的调节子序列的起始位置和终止位置,从而得出我们要想的结果。 三点重要:
?代码如下
一旦大于,就减去左区间的值 5.最难题螺旋矩阵||模拟顺时针画矩阵的过程:
由外向内一圈一圈这么画下去。 这里一圈下来,我们要画每四条边,这四条边怎么画,每画一条边都要坚持一致的左闭右开,或者左开右闭的原则,这样这一圈才能按照统一的规则画下来。 ?
|
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 | -2024/12/28 18:28:18- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |
数据统计 |