当前位置: 首页 > 编程日记 > 正文

快起床刷题去,别人把你offer拿走啦

好久没有上力扣刷题咯,又到了关键的时刻,却忘得零零散散,囧~
话说,刷题、学算法、常用,这些技能才能长在身上!

上一道刚刚遇到的正菜~
题:给定一个整数数组 nums 和一个目标值 k,请实现一个方法判断 nums 中是否存在某个片段(即若干个相连元素)之和等于 k。要求时间复杂度为 O(n)。
public boolean checkSum(int[] nums, int k) {// Write your code here.
}

首先分析题目,题目大意为:能否从一段数里找一段连续的数,组成这个给定的和。
这题第一眼:简单,这玩意儿弄俩指针划拉划拉就解决了。噫,一个指针就够了。
第二眼:这些好像怎么也不可能复杂度是O(n)啊~
怎么搞呢?
先看一下我第一次写的代码:

	{Map hashMap = new HashMap();int len = nums.length;int sum = 0;int index = 0;for (int i = 0;i < len;i++){sum += nums[i];if (!hashMap.containsKey(sum)){hashMap.put(sum,index);}if(sum > k){sum = 0;i = index++;}else if(sum == k){return true;}}return false;}

哈哈哈哈 我用了一个for,但是时间复杂度是O(n²)。吐了吐了~
真的是脑袋空白,没有思路了。翻了下之前的LeetCode的刷题记录,找到new一个数组的灵感。
如果我使用一个数组,就可以将一些计算记录存放起来,作用能顶一个指针!
于是,就有了新的想法,以下代码注释充分,常人可充分理解,若有不明请留言,言无不尽。

public static boolean checkSum(int[] nums, int k) {int len = nums.length;//使用一个数组存放前n项的和int sum [] = new int[len+1];HashMap hashMap = new HashMap();//第一圈循环 将到每个位置的和计算出来,放在数组中,再将数组中的元素下标存入hashmap中for (int i = 0; i < len; i++) {sum[i+1] = sum[i]+nums[i];//这里必须进行判断,若两个位置的和结果相等//如果有某个位置先得出一个和,则使用该和,这样在之后出现同样的和不会被覆盖if(!hashMap.containsKey(sum[i+1])){hashMap.put(sum[i+1],i);}}//如果有某个位置的和+k 能够等于下一个和//如,i处的和为10 而j处的和为20   i到j这段区间的和即为20-10for (int i = len; i > 0; i--) {if (hashMap.containsKey(sum[i]-k)){return true;}}return false;}

以上~ 自己还是一颗小白菜,学习 学习去吧!

相关文章:

oracle 提示:ORA-02292:integrity constraint(xxxxxxx) violated - child record found

当我们删除 数据的时候 oracle 提示:ORA-02292:integrity constraint(xxxxxxx) violated - child record found 这种情况呢是因为外键关联的存在&#xff0c;需删除另一个表的信息后才能将该信息删除。 这种情况首先应该去寻找是否有表与当前表存在关联&#xff0c;若能找到最…

分割数组(将数组三等分)

简单面试题——分割数组 时间复杂度O(n) //输入&#xff1a;一个自然数数组&#xff0c;选取其中2个数字num[i], num[j], 把数组三分&#xff0c; // 每一部分的累加和&#xff08;不包括分割点的数字&#xff09;相等。 // 例&#xff1a;nums[] [2,1,3,1,1,1,5,3]&am…

svn和git的本质区别是什么

上边图中,跨越了区的箭头,它中间的区数据都会同步。例如:git checkout ,它是将本地仓库数据更新到暂存区和工作区的。

使用JavaScript实现复杂功能:一个完整的电商网站搜索功能

随着互联网的发展,电子商务网站已经成为人们购物的重要平台。而在这些网站中,搜索功能无疑是核心功能之一。用户可以通过搜索快速找到他们需要的商品,从而提高购物体验。本文将详细介绍如何使用JavaScript实现一个完整的电商网站搜索功能。

牛年前的一小结——打响本命年的第一枪,继续刷题!

经过一段时间的小尝试&#xff0c;摸索出了一点点头儿吧。 总结一下子。 关于面试的java&#xff0c;像我这个经验层次&#xff08;1-2year普通厂&#xff09;的都不会太难。最多超不出力扣中等难度。 多练习链表、树、指针类的比较基础的题目&#xff1b;有解题方法并不是最重…

力扣1002.查找常用字符

力扣 1002. 查找常用字符 本人力扣练习已上传至码云&#xff0c;可互相学习借鉴。 难度-简单 题目&#xff1a; 给定仅有小写字母组成的字符串数组 A&#xff0c;返回列表中的每个字符串中都显示的全部字符&#xff08;包括重复字符&#xff09;组成的列表。例如&#xff0c;…

springboot项目使用junit4进行单元测试,maven项目使用junit4进行单元测试

首先&#xff0c;maven项目中引入依赖 <dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.11</version><scope>test</scope> </dependency><dependency><groupId>org.…

springboot设置文件上传大小(tomcat默认1M)

application.yml # 设置文件上传大小&#xff08;tomcat默认1M&#xff09; server:tomcat:max-http-form-post-size: -1 spring:servlet:multipart:max-file-size: 100MBmax-request-size: 500MB

kotlin重写构造方法编译报错:Primary constructor call expected

在kotlin中使用construct关键字定义构造方法&#xff0c;如果类定义时已经有构造方法&#xff08;类名后带括号&#xff09;&#xff0c;需要添加构造方法时&#xff0c;需要使用以下写法&#xff1a; class User(var name,var age){//使用 :this() 调用主构造方法对参数赋默认…

Linux下创建硬链接,文件访问为空,提示:xxxx: 符号连接的层数过多

Linux下创建软链接&#xff5c;硬链接&#xff0c;文件访问为空&#xff0c;提示&#xff1a;x x x: 符号连接的层数过多。 原因&#xff1a;创建符号链接的时候未使用绝对路径&#xff0c;无论是源文件路径还是目标路径&#xff0c;都需要使用绝对路径。 如&#xff1a; ln …

kotlin Bean加载失败lateinit property has not been initialized

Application run failed org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name ‘xxxApplicationConfig’: Unsatisfied dependency expressed through field ‘appConfigService’; nested exception is org.springframework.be…

Gradle错误提示:Java home supplied via ‘xxx.xxx.xxx‘ is invalid

Gradle错误提示&#xff1a;Java home supplied via ‘org.gradle.java.home’ is invalid 描述&#xff1a;在使用idea采用gradle进行依赖的管理功能&#xff0c;当想切换java版本时&#xff08;卸载现在的java版本&#xff0c;如jdk15&#xff0c;安装另外的java版本&#xf…

恭喜你发现了宝藏,编程习惯-日积月累

总结&#xff1a; 条件查询可在数据库层创建queryDto进行统一操作。 代码复用&#xff1a;若有代码重复出现了三次&#xff0c;很大概率可以重构。&#xff08;三则重构&#xff09; dto和entity中的赋值操作&#xff0c;可以写成方法放在dto中。&#xff08;充血模型&#x…

Gradle 将项目publish到Nexus,Kotlin将项目发布到nexus,springboot项目发布到maven仓库

示例见&#xff1a;Gitte 公仓设置 在项目中添加maven-publish的插件 plugins {kotlin("jvm") version "1.3.72"kotlin("plugin.spring") version "1.3.72"java-librarymaven-publishmaven }如同maven项目一样设置组、版本信息 gr…

妙用postman系列——postman建组、分享

妙用postman系列——postman建组、分享 添加新的组和请求。 3、生成分享链接 4、导入分享链接

Postman使用Date数据类型,Postman发送Date类型数据,Postman模拟前端调用

Postman使用Date数据类型&#xff1a; 在form-data数据类型下&#xff0c;使用 2021/7/7 11:11:00 &#xff08;yyyy/MM/dd HH:mm:ss&#xff09; 的数据格式即可 如下&#xff1a; 在json数据格式中&#xff0c;这种的则不能适用&#xff0c;需要在Per-request Script中设置…

IDEA中将代码块封装为方法,IDEA代码重构快捷键

IDEA中将代码块封装为方法 选中要转换的代码块&#xff0c;快捷键&#xff1a; Windows快捷键&#xff1a;Alt Shift M Mac快捷键&#xff1a;Alt Command M 如图&#xff1a;

Kotlin协程使用,协程使用注意事项,协程中的await方法使用|不使用suspend使用协程

参见 码云 协程使用方法一 &#xff08;Dispatchers调度器模式&#xff09; 指定不同线程。同线程会挂起并阻塞&#xff08;挂起是不影响主线程执行&#xff0c;阻塞是同样的IO线程会阻塞&#xff09; withContext(Dispatchers.IO) { // &#x1f448; 切换到 IO 线程&…

Alibaba Cloud Linux 2.1903 LTS 64位服务器yum源下载404,Alibaba Cloud Linux 2实例中使用docker-ce、epel等YUM源安装软件失败

[Alibaba Cloud Linux 2.1903 LTS 64位]服务器yum源下载404 failure: repodata/repomd.xml from docker-ce-stable: [Errno 256] No more mirrors to try. https://download.docker.com/linux/centos/2.1903/x86_64/stable/repodata/repomd.xml: [Errno 14] HTTPS Error 404 -…

OpenAPI使用(swagger3),Kotlin使用swagger3,Java使用swagger3,gradle、Maven使用swagger3

OpenAPI使用&#xff08;swagger3&#xff09; demo见Gitte 一、背景及名词解释 OpenAPI是规范的正式名称。规范的开发工作于2015年启动&#xff0c;当时SmartBear&#xff08;负责Swagger工具开发的公司&#xff09;将Swagger 2.0规范捐赠给了Open API Initiative&#xff0…

linux环境下nacos的安装+启动,阿里云服务器安装nacos

nacos安装启动&#xff08;linux环境&#xff09;&#xff1a; 基础&#xff1a;安装java环境 官网下载压缩包&#xff1a;如 nacos-server-1.2.1.tar.gz 放在自定义目录下 # 解压 tar -xvf nacos-server-1.2.1.tar.gz进入bin目录 cd nacos/bin # 启动 sh startup.sh -m sta…

SpringBoot项目使用nacos,kotlin使用nacos,java项目使用nacos,gradle项目使用nacos,maven项目使用nacos

SpringBoot项目使用nacos kotlin demo见Gitte 一、引入依赖 提示&#xff1a;这里推荐使用2.2.3版本&#xff0c;springboot与nacos的依赖需要版本相同&#xff0c;否则会报错。 maven版本 <dependency><groupId>com.alibaba.cloud</groupId><artifact…

使用第三方SDK(如微信、qq、快看、头条等),调用接口405 Method Not Allowed

使用第三方SDK&#xff08;如微信、qq、快看、头条等&#xff09;&#xff0c;调用接口405 Method Not Allowed 错误描述&#xff1a;postman请求正常&#xff0c;但客户端调用后接口没有反应&#xff0c;但返回了405错误。 解决方法&#xff1a;第三方sdk调用接口需要使用http…

ECS(Linux)连接RDS,使用命令行方式连接实例

使用命令行方式连接实例 通过命令行连接RDS MySQL数据库&#xff0c;连接方式如下&#xff1a; mysql -h<连接地址> -P<端口> -u<用户名> -p -D<数据库名称># 假设 用户testuser 密码123 数据库连接为 rm-bp1457xxxxxx.mysql.rds.aliyuncs.com mysql…

kotlin设置CORS跨域资源共享,java设置允许跨域,服务端如何设置 springboot中设置跨域资源共享

CORS通信过程&#xff0c;都是浏览器或http插件自动完成&#xff0c;不需要 用户/开发人员 参与。对于开发者来说&#xff0c;CORS通信与同源的AJAX通信没有差别&#xff0c;代码是完全一样的。浏览器一旦发现AJAX请求跨源&#xff0c;就会自动添加一些附加的头信息&#xff0c…

创建数据库,指定数据库的字符集和编码顺序

创建数据库&#xff0c;指定它的字符集和编码顺序 create database {数据库名称} CHARACTER SET {字符集} COLLATE {排序规则}举例&#xff1a; create database collage CHARACTER SET utf8mb4 COLLATE utf8_general_ci

Java | kotlin 手动注入bean,解决lateinit property loginService has not been initialized异常

kotlin.UninitializedPropertyAccessException: lateinit property loginService has not been initialized 注解类加载延迟导致的异常 解决方法一&#xff1a;工厂模式 建一个工厂类&#xff0c;如UserServiceFactory&#xff0c;使用该方法 java版&#xff1a; public abs…

kotlin中继承父属性使用构造方法

kotlin中继承父属性使用构造方法 1. 定义父类&#xff0c;给它两个属性&#xff1a; abstract class AbstractResponseMessage {private var success trueprivate var reason: String? nullconstructor() {}constructor(success: Boolean, reason: String?) {this.succes…

在kotlin companion object中读取spring boot配置文件,静态类使用@Value注解配置

在kotlin companion object中读取配置文件 静态类使用Value注解配置 class Config {Value("\${name}")fun setName(name: String) {Config.name name}companion object {private var name:String ? nullfun getName(): String {return name}} }在companion object…

微信公众号为指定openid用户推送消息

微信公众号为指定openid用户推送消息 微信提供的开放接口中&#xff0c;有两个给指定openid的用户发送信息的接口&#xff0c;适用场景应该是向 预约用户或者中奖用户发送消息。 第一个接口&#xff1a;客服发送消息 请求方式&#xff1a; POST 请求地址&#xff1a;https://a…