hot100之数组
最大子数组和(053)
先看代码
class Solution {
public int maxSubArray(int[] nums) {
int n = nums.length;
int subSum = 0;
int res = nums[0];
for (int i = 0; i < n; i++){
subSum = Math.max(nums[i], subSum+nums[i]);
res = Math.max(res, subSum);
}
return res;
}
}
- 分析
贪心+动态规划
判断前子数组是否对 subSum 产生负影响, 产生影响则放弃前子数组, 重新开始新的子数组
动态规划体现在计算当前的子数组和时,需要考虑前面的子数组和是否对当前有贡献。贪心体现在如果前面的子数组和为负数,就直接舍弃重新开始计算。这道题的关键在于理解subSum代表以当前元素结尾的最大子数组和。
- 感悟
因为前值会对后值产生影响 , 让人自然想到动态规划
由于后值只需要前一个状态的值 我们可以用 subSum作滚动计算 ,优化空间复杂度
合并区间(056)
先看代码
class Solution {
public int[][] merge(int[][] intervals) {
Arrays.sort(intervals, (p, q)-> p[0] - q[0]);
List<int []> res = new ArrayList<>();
for(int[] p : intervals){
int m = res.size();
if (m > 0 && p[0] <= res.get(m-1)[1]){
res.get(m-1)[1] = Math.max(res.get(m-1)[1], p[1]);
}else res.add(p);
}
return res.toArray(new int[res.size()][]);
}
}
- 分析
利用左端点进行排序, 再组合
- 感悟
左端点排序可以不破坏p[k-1]与 p[k]一致, 递增
轮转数组(189)
先看代码
class Solution {
public void rotate(int[] nums, int k) {
int n = nums.length;
k %= n;
reverse(nums, 0, n-1);
reverse(nums, 0, k-1);
reverse(nums, k, n-1);
}
private void reverse(int[] nums, int lef, int rig){
while (lef < rig){
int temp = nums[lef];
nums[lef++] = nums[rig];
nums[rig--] = temp;
}
}
}
- 分析
先对整体数组翻转, 在以k为节点 左右各自翻转
- 感悟
数学 真神奇吧
除自身以外数的乘积(238)
先看代码
class Solution {
public int[] productExceptSelf(int[] nums) {
int n = nums.length;
int[] preSum = new int[n];
preSum[0] = 1;
int[] sufSum = new int[n];
sufSum[n-1] = 1;
for(int i = 1; i < n ; i++){
preSum[i] = preSum[i-1] * nums[i-1];
}
for(int i = n-2; i >= 0; i--){
sufSum[i] = sufSum[i+1] * nums[i+1];
}
int[] res = new int[n];
for(int i = 0; i < n; i++){
res[i] = preSum[i] * sufSum[i];
}
return res;
}
}
- 分析
分别计算数组的前缀积与后缀积
用 i之前的前缀积 * i之和的后缀积
res[i] = preSum[i] * sufSum[i]
preSum[0] = 1 sufSum[n-1] = 1
可知 preSum[i] 为 num[0] * …. * num[i-1]
同理 sufSum[i] 为 num[n-1] * …. * num[i+1]
可知preSum[i] * sufSum[i]不包含 num[i]
- 感悟
分解数据的前后缀再求解
缺失的第一个正数(041)
先看代码
class Solution {
public int firstMissingPositive(int[] nums) {
int n = nums.length;
for (int i = 0; i < n; i++){
while(0 < nums[i] && nums[i] <= n && nums[i] != nums[nums[i] - 1]){
int j = nums[i] - 1;
int temp = nums[j];
nums[j] = nums[i];
nums[i] = temp;
}
}
for (int i = 0; i < n; i++){
if (nums[i] != i+1){
return i+1;
}
}
return n+1;
}
}
- 分析
还是分座位, 如果i号座位上坐的人不是i , 让出座位给i
- 感悟
将理论问题生活化. 生活中的一个直觉, 背后可能有丰富的理论
hot100之数组的更多相关文章
- leadcode的Hot100系列--17. 电话号码的字母组合--回溯的另一种想法的应用
提交leetcode的时候遇到了问题,一直说访问越界,但仔仔细细检查n多遍,就是检查不出来. 因为我用到了count全局变量,自加一来表明当前数组访问的位置, 后来突然想到,是不是在leetcode在 ...
- javascript中的Array对象 —— 数组的合并、转换、迭代、排序、堆栈
Array 是javascript中经常用到的数据类型.javascript 的数组其他语言中数组的最大的区别是其每个数组项都可以保存任何类型的数据.本文主要讨论javascript中数组的声明.转换 ...
- 探究javascript对象和数组的异同,及函数变量缓存技巧
javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...
- 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)
建议75:集合中的元素必须做到compareTo和equals同步 实现了Comparable接口的元素就可以排序,compareTo方法是Comparable接口要求必须实现的,它与equals方法 ...
- 了解PHP中的Array数组和foreach
1. 了解数组 PHP 中的数组实际上是一个有序映射.映射是一种把 values 关联到 keys 的类型.详细的解释可参见:PHP.net中的Array数组 . 2.例子:一般的数组 这里,我 ...
- JavaScript权威指南 - 数组
JavaScript数组是一种特殊类型的对象. JavaScript数组元素可以为任意类型,最大容纳232-1个元素. JavaScript数组是动态的,有新元素添加时,自动更新length属性. J ...
- JavaScript常见的五种数组去重的方式
▓▓▓▓▓▓ 大致介绍 JavaScript的数组去重问题在许多面试中都会遇到,现在做个总结 先来建立一个数组 var arr = [1,2,3,3,2,'我','我',34,'我的',NaN,NaN ...
- js:给定两个数组,如何判断他们的相对应下标的元素类型是一样的
题目: 给Array对象原型上添加一个sameStructureAs方法,该方法接收一个任意类型的参数,要求返回当前数组与传入参数数组(假定是)相对应下标的元素类型是否一致. 假设已经写好了Array ...
- javascript数组查重方法总结
文章参考地址:http://blog.csdn.net/chengxuyuan20100425/article/details/8497277 题目 对下列数组去重: var arr = ['aa', ...
- 掌握javascript中的最基础数据结构-----数组
这是一篇<数据结构与算法javascript描述>的读书笔记.主要梳理了关于数组的知识.部分内容及源码来自原作. 书中第一章介绍了如何配置javascript运行环境:javascript ...
随机推荐
- 如何避免VMware平台ESXi主机CPU使用率的“坑”?
https://mp.weixin.qq.com/s?__biz=MjM5NTk0MTM1Mw==&mid=2650636818&idx=1&sn=c43f3a3146092f ...
- Docker IPv6 网络环境配置
由于目前Docker 在IPv6网络中运行的相关配置并非默认自动生成的,所以需要大家根据自己的网络环境来具体做一些相应配置,具体如下: 本次操作是在 Ubuntu16/18或者CentOS7 OS上面 ...
- iOS Facebook和Google登录
前言 最近在对接完Google和Facebook登录之后准备对这部分内容做一个小小的总结,方便以后有需要的时候查看. 具体的Google账号申请和Facebook账号的申请在这里就不做介绍了,这部分内 ...
- C 冒泡排序和选择排序
冒泡排序 理论概念: 从第一个数开始,将相邻的两个数比较,第一个数和第二个数比较,比如说是从小到大的排序,要是后面的数比前面的小则交换两个的位置,这样第一轮比较基数后最大的数就到了最后面,接着进行第二 ...
- 干货分享!MCP 实现原理,小白也能看懂
不知道大家有没有发现?对于添加到 MCP 服务市场的成千上万个 MCP 服务(而且这个数字每天还在增加),我们可以不写一行代码,轻松实现调用,但背后的原因究竟是啥呢? MCP 虽然用起来很方便,但搞不 ...
- classpath类路径
一.classpath类路径,包含java包下和resource下
- mybatis——分页插件PageHelper的使用
项目开发中涉及列表查询时,经常会需要对查询结果进行分页处理:常用的一个插件--PageHelper,是国内非常优秀的一款开源的mybatis分页插件,它支持基本主流与常用的数据库,一致支持mysql. ...
- python调用QQ机器人向指定QQ发消息
暂时没想到这个能用来干什么,只是刚好看到相关文章,学习一下,就拿获取基金信息来做试验把 爬取基金的信息就不介绍了,请参考https://www.cnblogs.com/becks/p/14500495 ...
- ADTF: 助力自动驾驶系统开发的强大工具箱!
在过去十年中,自动驾驶和高级驾驶辅助系统(AD/ADAS)软件与硬件的快速发展对多传感器数据采集的设计需求提出了更高的要求.然而,目前仍缺乏能够高质量集成多传感器数据采集的解决方案. 康谋ADTF正是 ...
- FreeSWITCH中SIP网关(Gateway)操作
freeswitch是一款简单好用的VOIP开源软交换平台. 以下是一篇关于FreeSWITCH中SIP网关(Gateway)操作的技术指南,基于提供的官方文档内容整理: 一.网关生命周期管理 1. ...