Leetcode数组题*3
Leetcode数组题*3
66.加一
题目描述
- 给定一个由整数组成的非空数组所表示的非负整数,在该数的基础上加一。
- 最高位数字存放在数组的首位, 数组中每个元素只存储单个数字。
- 你可以假设除了整数 0 之外,这个整数不会以零开头。
示例:
输入: [1,2,3]
输出: [1,2,4]
解释: 输入数组表示数字 123。
链接:https://leetcode-cn.com/problems/plus-one
思路分析
参考题解大神的巧妙解法:Java数学解题
一个数用数组存储,那么加上1之后只有两种情况
- 最后一位不是9,直接让数组的最后一位加1后返回该数组。
- 最后一位是9的情况,需要在循环中判断,因为它的前面一位也可能是9,首先让9变为0,然后前一位加1。
- 如果最高位为9,可以创建一个新的数组,长度比原数组长度大一,首位置0。
/**
* 将一个用表示数字的数组传入,加上1之后,返回新数组
* @param digits 传入的数组
* @return 返回加一之后的新数组
*/
public static int[] plusOne(int[] digits){
int len = digits.length;
for(int i = len-1;i>=0;i--){
digits[i]++;
digits[i] = digits[i]%10;
//末位不是9,直接返回
if(digits[i]!=0) return digits;
}
//最高位为9的情况,创建一个比原数组长1的数组
int[] newDigits = new int[len+1];
//首位置1,其余初始化为0
newDigits[0] = 1;
return newDigits;
}
88.合并两个有序数组
题目描述
- 给定两个有序整数数组 nums1 和 nums2,将 nums2 合并到 nums1 中,使得 num1 成为一个有序数组。
说明:
- 初始化 nums1 和 nums2 的元素数量分别为 m 和 n。
- 你可以假设 nums1 有足够的空间(空间大小大于或等于 m + n)来保存 nums2 中的元素。
示例:
输入:
nums1 =[1,2,3,0,0,0],m =3
nums2 =[2,5,6],n =3
输出: [1,2,2,3,5,6]
链接:https://leetcode-cn.com/problems/merge-sorted-array
思路分析
参考题解:画解算法
- 由于nums1有足够的空间撑下两个数组,可以从后向前处理排序加合并。
- 设置指向两个数组数字尾部的指针p1和p2,和一个指向刚好是合并数组的最后一位的指针p。
- 从后向前比较两个数组中的值,将大的放入nums1的后面,依次向前填充。
- 当nums1中没有数的时候,将nums2全部拷贝到nums1的前面。
/**
* 合并并排序到第一个数组
*
* @param nums1 传入的第一个数组
* @param m 第一个数组的长度
* @param nums2 传入的第二个数组
* @param n 第二个数组的长度
*/
public static void merge(int[] nums1, int m, int[] nums2, int n) {
int p1 = m - 1;//指向nums1的有数字的最后一位
int p2 = n - 1;//指向nums2的有数字的最后一位
int p = m + n - 1;
//从有数字的最后一位向前,一一对比,两者较大的数存到nums1的p位置,分别向前
while (p1 >= 0 && p2 >= 0) {
nums1[p--] = nums1[p1] > nums2[p2] ? nums1[p1--] : nums2[p2--];
}
//由于是存到nums1上的,所以保证最后p1无元素可指的时候,把nums2上的元素按顺序拷贝到nums1
System.arraycopy(nums2, 0, nums1, 0, p2 + 1);
}
167.两数之和Ⅱ-输入有序数组
题目描述
给定一个已按照升序排列 的有序数组,找到两个数使得它们相加之和等于目标数。
函数应该返回这两个下标值 index1 和 index2,其中 index1 必须小于 index2。
说明:
返回的下标值(index1 和 index2)不是从零开始的。
你可以假设每个输入只对应唯一的答案,而且你不可以重复使用相同的元素。
示例:
输入: numbers = [2, 7, 11, 15], target = 9
输出: [1,2]
解释: 2 与 7 之和等于目标数 9 。因此 index1 = 1, index2 = 2 。
链接:https://leetcode-cn.com/problems/two-sum-ii-input-array-is-sorted
思路分析
参考题解:双指针求解两数之和
- 注意是已排序数组,可以利用这一点求解。
- 双指针求解,一指针指向前,一指针指向后。
- 如果两个指针对应的和刚好是target,返回两个指针对应索引+1。
- 如果和大于target,就将大数指针向前移动。反之,小数指针向后移动。
/**
* 得到传入数组中两个元素和刚好是目标数字的位置,用数组返回
* @param numbers 传入的目标数组
* @param target 传入的目标数字
* @return 返回两元素和为目标数字的对应位置
*/
public static int[] twoSum(int[] numbers,int target){
int i = 0;
int j = numbers.length-1;
if(numbers == null) return null;
while(i<j){
int sum = numbers[i]+numbers[j];
if(sum==target) return new int[]{i+1,j+1};
else if(sum>target){
j--;
}else{
i++;
}
}
return null;
}
Leetcode数组题*3的更多相关文章
- LeetCode刷题总结-数组篇(上)
数组是算法中最常用的一种数据结构,也是面试中最常考的考点.在LeetCode题库中,标记为数组类型的习题到目前为止,已累计到了202题.然而,这202道习题并不是每道题只标记为数组一个考点,大部分习题 ...
- LeetCode刷题总结-数组篇(中)
本文接着上一篇文章<LeetCode刷题总结-数组篇(上)>,继续讲第二个常考问题:矩阵问题. 矩阵也可以称为二维数组.在LeetCode相关习题中,作者总结发现主要考点有:矩阵元素的遍历 ...
- LeetCode刷题总结-数组篇(下)
本期讲O(n)类型问题,共14题.3道简单题,9道中等题,2道困难题.数组篇共归纳总结了50题,本篇是数组篇的最后一篇.其他三个篇章可参考: LeetCode刷题总结-数组篇(上),子数组问题(共17 ...
- LeetCode刷题总结-数组篇(番外)
本期共7道题,三道简单题,四道中等题. 此部分题目是作者认为有价值去做的一些题,但是其考察的知识点不在前三篇总结系列里面. 例1解法:采用数组索引位置排序的思想. 例2解法:考察了组合数学的组合公式应 ...
- C#LeetCode刷题-数组
数组篇 # 题名 刷题 通过率 难度 1 两数之和 C#LeetCode刷题之#1-两数之和(Two Sum) 43.1% 简单 4 两个排序数组的中位数 C#LeetCode刷题之#4-两个排序数组 ...
- LeetCode算法题-Subdomain Visit Count(Java实现)
这是悦乐书的第320次更新,第341篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第189题(顺位题号是811).像"discuss.leetcode.com& ...
- LeetCode算法题-Number of Lines To Write String(Java实现)
这是悦乐书的第319次更新,第340篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第188题(顺位题号是806).我们要将给定字符串S的字母从左到右写成行.每行最大宽度为 ...
- LeetCode算法题-Unique Morse Code Words(Java实现)
这是悦乐书的第318次更新,第339篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第186题(顺位题号是804).国际莫尔斯电码定义了一种标准编码,其中每个字母映射到一系 ...
- LeetCode刷题专栏第一篇--思维导图&时间安排
昨天是元宵节,过完元宵节相当于这个年正式过完了.不知道大家有没有投入继续投入紧张的学习工作中.年前我想开一个Leetcode刷题专栏,于是发了一个投票想了解大家的需求征集意见.投票于2019年2月1日 ...
随机推荐
- clr via c# 定制特性
1,特性的应用范围:特性可应用于程序集,模块,类型,字段,方法,方法参数,方法返回值,属性,参数,泛型参数 2,利用前缀告诉编译器表明意图---下面的倾斜是必须的表明了我们的目标元素: [assemb ...
- 使用十年的电脑在家用记事本调试 .NET 程序
引言 春节放假回老家,没有把笔记本电脑带上,由于肺炎疫情的原因只能呆在家里,写的一个WinForm程序无法正常使用,需要及时修复,看我如何使用家里十年的台式机来调试修复 .NET 应用程序. WinF ...
- 基于SSM开发学生信息管理系统源码
开发环境: Windows操作系统开发工具: Eclipse+Jdk+Tomcat+MySql数据库 运行效果图 源码及原文链接:https://javadao.xyz/forum.php?mo ...
- 定义了一个vue全局方法,不能再vuex中进行调用
你把函数定义在 Vue 的原型链上,只能在 Vue 的实例里才能取到这个方法. vue组件 是一个Vue 的实例,所以你当然能在这里调用到 ajax 方法. 而,vuex 只是一个 vue插件,在 v ...
- 044.Python线程的数据安全
线程的数据安全 1 数据混乱现象 from threading import Thread,Lock num = 0 lst = [] def func1(): global num for i in ...
- 前后端分离-crud&svn
前后端分离-crud&svn 1. 跨域 1.1 什么是跨域 请求方与服务方的源不同,即跨域,包括: 1. 协议不同 2. 域名不同 3. 端口不同 1.2 跨域不一定存在跨域问题 什么情况下 ...
- css背景颜色、背景图片,以及列表的多种样式
背景样式 • background-color 设置元素的背景颜色.• background-image 把图像设置为背景.• background-position 设置背景图像的起始位置.• ba ...
- 【sklearn】Toy datasets上的分类/回归问题 (XGBoost实践)
分类问题 1. 手写数字识别问题 from sklearn.datasets import load_digits digits = load_digits() # 加载手写字符识别数据集 X = d ...
- 03-React基础语法(3)
一.Context 概念:Context 提供一个无需在每层组件中添加Props,就可以实现组件组件之间通信的方法 语法: 1创建context对象 const {Provider, Consum ...
- MySQL 8 服务端帮助支持
MySQL 服务器支持 HELP 语句,该语句返回参考手册中相应信息,比如: mysql> help change master to; 返回创建主从复制相关语句的信息 参考手册的信息存储在my ...