【笔试实战】LeetCode题单刷题-编程基础 0 到 1【二】
1822. 数组元素积的符号
题目链接
题目描述
已知函数 signFunc(x)
将会根据 x
的正负返回特定值:
- 如果
x
是正数,返回1
。 - 如果
x
是负数,返回-1
。 - 如果
x
是等于0
,返回0
。
给你一个整数数组 nums
。令 product
为数组 nums
中所有元素值的乘积。
返回 signFunc(product)
。
示例 1:
输入:nums = [-1,-2,-3,-4,3,2,1]
输出:1
解释:数组中所有值的乘积是 144 ,且 signFunc(144) = 1
示例 2:
输入:nums = [1,5,0,2,-3]
输出:0
解释:数组中所有值的乘积是 0 ,且 signFunc(0) = 0
示例 3:
输入:nums = [-1,1,-1,1,-1]
输出:-1
解释:数组中所有值的乘积是 -1 ,且 signFunc(-1) = -1
提示:
1 <= nums.length <= 1000
-100 <= nums[i] <= 100
解题思路一【Java语言】
时间0 ms 击败 100%
内存41.9 MB 击败 20.81%
这道题是判断给定数组中的元素有多少个负数,根据负数的个数决定返回1还是-1。如果数组中有0,直接返回0。
具体解题思路如下:
- 初始化一个变量negative用于记录负数的个数。
- 遍历给定数组nums中的每一个元素。
- 如果当前元素num等于0,则直接返回0。
- 如果当前元素num小于0,则将负数个数negative加一。
- 遍历完数组后,判断负数个数negative是否为奇数,如果是则返回-1,否则返回1。
这个程序用到的知识点包括:
- 循环结构:使用for循环遍历数组中的每一个元素。
- 分支结构:使用if语句判断当前元素是否为0或负数。
- 算术运算:使用求余运算符判断负数个数是否为奇数。
- 数组:使用数组来存储给定的整数序列。
class Solution {
public int arraySign(int[] nums) {
int negative=0;
for(int num:nums){
if(num==0){
return 0;
}
if(num<0){
negative++;
}
}
return negative%2==1?-1:1;
}
}
1502. 判断能否形成等差数列
题目链接
题目描述
给你一个数字数组 arr
。
如果一个数列中,任意相邻两项的差总等于同一个常数,那么这个数列就称为 等差数列 。
如果可以重新排列数组形成等差数列,请返回 true
;否则,返回 false
。
示例 1:
输入:arr = [3,5,1]
输出:true
解释:对数组重新排序得到 [1,3,5] 或者 [5,3,1] ,任意相邻两项的差分别为 2 或 -2 ,可以形成等差数列。
示例 2:
输入:arr = [1,2,4]
输出:false
解释:无法通过重新排序得到等差数列。
提示:
2 <= arr.length <= 1000
-10^6 <= arr[i] <= 10^6
解题思路一【Java语言】
时间1 ms 击败 97.94%
内存39.9 MB 击败 15.26%
这道题是判断给定数组arr是否能够构成等差数列。如果能够构成等差数列,则返回true;否则,返回false。
具体解题思路如下:
- 引入java.util.Arrays中的sort方法对给定数组arr进行排序。
- 使用for循环遍历数组中的每一个元素arr[i],从索引1开始,并且遍历到倒数第二个元素。
- 在循环中,判断当前元素arr[i]与其前一个元素arr[i-1]的差是否等于当前元素arr[i+1]与arr[i]的差。如果不相等,则说明不能构成等差数列,返回false。
- 如果循环结束后仍然没有返回false,则说明数组arr中的每个元素都满足等差数列的条件,返回true。
这个程序用到的知识点包括:
- 数组:使用数组来存储给定的整数序列。
- 引入其他类:使用import语句引入java.util包中的ArrayList类。
- 数据排序:使用Arrays类中的sort方法对数组进行排序。
- 循环结构:使用for循环遍历数组中的每一个元素。
- 分支结构:使用if语句判断等差数列的条件,并根据判断结果返回对应的布尔值。
import java.util.ArrayList;
class Solution {
public boolean canMakeArithmeticProgression(int[] arr) {
Arrays.sort(arr);
for(int i=1; i<arr.length-1; i++){
if(arr[i]-arr[i-1]!=arr[i+1]-arr[i]){
return false;
}
}
return true;
}
}
896. 单调数列
题目链接
题目描述
如果数组是单调递增或单调递减的,那么它是 单调 的。
如果对于所有 i <= j
,nums[i] <= nums[j]
,那么数组 nums
是单调递增的。 如果对于所有 i <= j
,nums[i]> = nums[j]
,那么数组 nums
是单调递减的。
当给定的数组 nums
是单调数组时返回 true
,否则返回 false
。
示例 1:
输入:nums = [1,2,2,3]
输出:true
示例 2:
输入:nums = [6,5,4,4]
输出:true
示例 3:
输入:nums = [1,3,2]
输出:false
提示:
1 <= nums.length <= 105
-105 <= nums[i] <= 105
解题思路一【Java语言】
时间1 ms 击败 97.87%
内存53.8 MB 击败 51.24%
这道题的解题思路是判断给定数组nums是否是单调的(单调递增或单调递减)。如果是单调的,则返回true;否则,返回false。
具体解题思路如下:
- 首先检查数组的长度。如果数组只有一个元素,则认为是单调的,直接返回true。如果数组为空,即长度为0,则认为不是单调的,直接返回false。
- 判断数组的单调性。如果数组的第一个元素小于等于最后一个元素,说明是单调递增的情况,执行递增判断的循环操作;否则,执行递减判断的循环操作。
- 在循环中,遍历数组中的每个元素nums[i],从索引1开始。
- 如果是递增判断,判断当前元素nums[i]是否小于前一个元素nums[i-1],如果小于,则说明不是单调的,返回false。
- 如果是递减判断,判断当前元素nums[i]是否大于前一个元素nums[i-1],如果大于,则说明不是单调的,返回false。
- 如果循环结束后没有返回false,则说明数组nums是单调的,返回true。
这个程序用到的知识点包括:
- 数组:使用数组来存储给定的整数序列。
- 循环结构:使用for循环遍历数组中的每一个元素。
- 分支结构:使用条件判断语句if来判断数组的单调性,并根据判断结果返回对应的布尔值。
class Solution {
public boolean isMonotonic(int[] nums) {
if(nums.length == 1) return true;
if( nums.length == 0) return false;
if( nums[0] <= nums[nums.length - 1]){
for(int i = 1 ; i < nums.length ; i++){
if( nums[i] < nums[i-1] )
return false;
}
}else{
for(int i = 1 ; i < nums.length ; i++){
if( nums[i] > nums[i-1])
return false;
}
}
return true;
}
}
13. 罗马数字转整数
题目链接
题目描述
罗马数字包含以下七种字符: I
, V
, X
, L
,C
,D
和 M
。
字符 数值
I 1
V 5
X 10
L 50
C 100
D 500
M 1000
例如, 罗马数字 2
写做 II
,即为两个并列的 1 。12
写做 XII
,即为 X
+ II
。 27
写做 XXVII
, 即为 XX
+ V
+ II
。
通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII
,而是 IV
。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX
。这个特殊的规则只适用于以下六种情况:
I
可以放在V
(5) 和X
(10) 的左边,来表示 4 和 9。X
可以放在L
(50) 和C
(100) 的左边,来表示 40 和 90。C
可以放在D
(500) 和M
(1000) 的左边,来表示 400 和 900。
给定一个罗马数字,将其转换成整数。
示例 1:
输入: s = "III"
输出: 3
示例 2:
输入: s = "IV"
输出: 4
示例 3:
输入: s = "IX"
输出: 9
示例 4:
输入: s = "LVIII"
输出: 58
解释: L = 50, V= 5, III = 3.
示例 5:
输入: s = "MCMXCIV"
输出: 1994
解释: M = 1000, CM = 900, XC = 90, IV = 4.
提示:
1 <= s.length <= 15
s
仅含字符('I', 'V', 'X', 'L', 'C', 'D', 'M')
- 题目数据保证
s
是一个有效的罗马数字,且表示整数在范围[1, 3999]
内 - 题目所给测试用例皆符合罗马数字书写规则,不会出现跨位等情况。
- IL 和 IM 这样的例子并不符合题目要求,49 应该写作 XLIX,999 应该写作 CMXCIX 。
- 关于罗马数字的详尽书写规则,可以参考 罗马数字 - Mathematics。
解答思路一【Java】
时间4 ms 击败 58.6%
内存42.5 MB 击败 40.64%
解题思路是将给定的罗马数字字符串s转换为对应的整数值。具体解题思路如下:
首先创建一个HashMap,用于存储罗马数字与对应的整数关系。将每个罗马数字字符作为键,对应的整数值作为值,存入HashMap中。
初始化一个变量result,用于存储最终的整数结果。
使用for循环遍历字符串s中的每一个字符。
在循环中,获取当前字符的对应整数值,通过map.get()方法获取。
判断下一个字符是否存在,并且下一个字符对应的数值是否大于当前字符对应的数值。如果满足条件,说明需要进行减法运算,将当前字符对应的数值取反后加入result;否则,将当前字符对应的数值加入result。
遍历完成后,返回最终的整数结果result。
这个程序用到的知识点包括:
- HashMap:使用哈希映射来建立罗马数字与整数之间的关系。
- 字符串的遍历:使用for循环遍历字符串中的每一个字符。
- 条件判断:根据当前字符及其后一个字符的数值大小关系,确定是否需要进行减法运算。
- 字符串与整数的转换:通过map.get()方法获取字符对应的整数值,并进行相应的运算。
class Solution {
public int romanToInt(String s) {
HashMap<Character, Integer> map = new HashMap<>();
map.put('I', 1);
map.put('V', 5);
map.put('X', 10);
map.put('L', 50);
map.put('C', 100);
map.put('D', 500);
map.put('M', 1000);
int result = 0;
for (int i = 0; i < s.length(); i++) {
int currentValue = map.get(s.charAt(i));
// 如果下一个字符存在且比当前字符对应的数值大,则将当前数值取反加入result
if (i < s.length() - 1 && map.get(s.charAt(i + 1)) > currentValue) {
result -= currentValue;
} else {
result += currentValue;
}
}
return result;
}
}
58. 最后一个单词的长度
题目链接
题目描述
给你一个字符串 s
,由若干单词组成,单词前后用一些空格字符隔开。返回字符串中 最后一个 单词的长度。
单词 是指仅由字母组成、不包含任何空格字符的最大子字符串。
示例 1:
输入:s = "Hello World"
输出:5
解释:最后一个单词是“World”,长度为5。
示例 2:
输入:s = " fly me to the moon "
输出:4
解释:最后一个单词是“moon”,长度为4。
示例 3:
输入:s = "luffy is still joyboy"
输出:6
解释:最后一个单词是长度为6的“joyboy”。
提示:
1 <= s.length <= 104
s
仅有英文字母和空格' '
组成s
中至少存在一个单词
解题思路一【Java】
时间0 ms 击败 100%
内存39.8 MB 击败 40.23%
具体解题思路如下:
使用split方法将字符串s按照空格进行拆分,得到一个字符串数组temp。拆分后,数组temp的最后一个元素就是最后一个单词。
返回数组temp中最后一个元素的长度,即temp[temp.length-1].length()。
这个程序用到的知识点包括:
- 字符串的拆分:使用split方法按照指定的分隔符将字符串拆分为字符串数组。
- 数组的使用:通过数组索引获取字符串数组中的元素。
- 字符串的长度计算:使用length()方法获取字符串的长度。
class Solution {
public int lengthOfLastWord(String s) {
String temp[]=s.split(" ");
return temp[temp.length-1].length();
}
}
709. 转换成小写字母
题目链接
题目描述
给你一个字符串 s
,将该字符串中的大写字母转换成相同的小写字母,返回新的字符串。
示例 1:
输入:s = "Hello"
输出:"hello"
示例 2:
输入:s = "here"
输出:"here"
示例 3:
输入:s = "LOVELY"
输出:"lovely"
提示:
1 <= s.length <= 100
s
由 ASCII 字符集中的可打印字符组成
解答思路一【Java】
时间0 ms 击败 100%
内存39.5 MB 击败 75.76%
class Solution {
public String toLowerCase(String s) {
return s.toLowerCase();
}
}
工程日志
2023-07-04
- 之前提到要绕开题目给的误导性思路,但是一直拿不出来一个合适的方向,今天的1822. 数组元素积的符号题目让我有了一点方向,我愿称之为透过现象看本质
- 这部分的题目普遍都比较简单,迷惑性的特点占多一些,逻辑性的要求较少,基本上只要能够看透本质,都是能秒杀的题目
【笔试实战】LeetCode题单刷题-编程基础 0 到 1【二】的更多相关文章
- leetcode简单刷题
[python3]参数中的冒号与箭头 冒号后面是建议传入的参数类型 箭头后面是建议函数返回的类型
- 【shell编程基础0】bash shell编程的基本配置
前面一篇“shell编程之变量篇”主要讲述下shell编程的变量的基本知识:设置变量的方式,自定义变量和环境变量的差别,变量的替换.删除.测试等. 这一篇主要是讲述在bash shell下的一些基本配 ...
- python编程基础知识—列表(二)
3操作列表 3.1 遍历整个列表 使用for循环 cars = ['bmw','audi','toyota','Jeep'] for i in cars: print(i) bmw audi toyo ...
- Java编程基础阶段笔记 day06 二维数组
二维数组 笔记Notes 二维数组 二维数组声明 二维数组静态初始化与二位初始化 二维数组元素赋值与获取 二维数组遍历 二维数组内存解析 打印杨辉三角 Arrays工具类 数组中常见的异常 二维数组 ...
- LeetCode第[18]题(Java):4Sum 标签:Array
题目难度:Medium 题目: Given an array S of n integers, are there elements a, b, c, and d in S such that a + ...
- leetcode 第188题,我的解法,Best Time to Buy and Sell Stock IV
<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255) ...
- leetcode第37题--Count and Say
题目:(据说是facebook的面试题哦) The count-and-say sequence is the sequence of integers beginning as follows:1, ...
- LeetCode第[1]题(Java):Two Sum 标签:Array
题目: Given an array of integers, return indices of the two numbers such that they add up to a specifi ...
- LeetCode的刷题利器(伪装到老板都无法diss你没有工作)
在工程效率大行其道的今天,如果不会写点代码以后也不容易在测试圈混下去.今天给大家推荐一个LeetCode的刷题利器,可以伪装到连你老板在这里走过去都无法确认你是在干活呢,还是在干活呢. LeetCod ...
- [LeetCode] 系统刷题5_Dynamic Programming
Dynamic Programming 实际上是[LeetCode] 系统刷题4_Binary Tree & Divide and Conquer的基础上,加上记忆化的过程.就是说,如果这个题 ...
随机推荐
- [大数据]sqoop安装与运用
1 文由 项目使用场景:OLTP Oracle 数据导入到 OLAP HIVE 2 Sqoop简述 Apache Sqoop(TM) 是一款开源的ETL工具,设计用于在 Apache Hadoop和结 ...
- Java设计模式 —— 外观模式
13 外观模式 13.1 外观模式概述 Facade Pattern: 为子系统的接口提供一组统一的入口.外观模式定义了一个高层接口,这个接口使得子系统的更加容易使用. 在外观模式中,一个子系统的外部 ...
- axios文件下载!!!!
前端 download(){ debugger; this.loading = true; axios.post('http://localhost:8081/brand_case/dao.do?me ...
- 33-module
const { resolve } = require('path') const HtmlWebpackPlugin = require('html-webpack-plugin') module. ...
- javasec(一)java反射
这篇文章介绍javasec基础知识--java反射. 0x01 反射是什么? 反射是一种机制,利用反射机制动态的实例化对象.读写属性.调用方法.构造函数. 在程序运行状态中,对于任意一个类或对象,都能 ...
- 分布式文件存储MinIO、安装和使用
1.MinIO简介 MinIO是高性能的对象存储,单个对象最大可达5TB.适合存储图片.视频.文档.备份数据.安装包等一系列文件.是一款主要采用Golang语言实现发开的高性能.分布式的对象存储系统. ...
- C# 闭包类对弱引用的坑
闭包.弱引用的简单概念,大佬们描述的很多,有不了解的可以看看: 理解C#中的闭包 - 黑洞视界 - 博客园 (cnblogs.com) C#弱引用(WeakReference) - 简书 (jians ...
- 基于pyinstaller的python打包工具
以下是软件链接:https://mysecreat.lanzoub.com/iZPGf0swgtbc 软件功能:可以对py文件进行打包,功能基于pyinstaller模块,因此需要安装python环境 ...
- npm init vite@latest; 项目名字是abcde,选了vue-ts; cd abcde; npm install; npm run dev;浏览器访问,结果是空白的,这是怎么回事?
npm init vite@latest 项目名字是abcde,选了vue-ts cd abcde npm install npm run dev 浏览器访问,结果是空白的,这是怎么回事? 后来发现是 ...
- 2021-04-22:给定很多线段,每个线段都有两个数[start, end],表示线段开始位置和结束位置,左右都是闭区间,规定:1)线段的开始和结束位置一定都是整数值,2)线段重合区域的长度必须>=
2021-04-22:给定很多线段,每个线段都有两个数[start, end],表示线段开始位置和结束位置,左右都是闭区间,规定:1)线段的开始和结束位置一定都是整数值,2)线段重合区域的长度必须&g ...