Arithmetic Slices

这两天一直复习动态规划,就想到leetcode上刷刷题,easy难度的很少,大部分都是medium和hard。本题是第一道DP类型medium难度的题目,但是用其他的方法比如暴力法也可以求解。首先来看题目描述:

A sequence of number is called arithmetic if it consists of at least three elements and if the difference between any two consecutive elements is the same.

For example, these are arithmetic sequence:

1, 3, 5, 7, 9
7, 7, 7, 7
3, -1, -5, -9

The following sequence is not arithmetic.

1, 1, 2, 5, 7

A zero-indexed array A consisting of N numbers is given. A slice of that array is any pair of integers (P, Q) such that 0 <= P < Q < N.

A slice (P, Q) of array A is called arithmetic if the sequence:
A[P], A[p + 1], ..., A[Q - 1], A[Q] is arithmetic. In particular, this means that P + 1 < Q.

The function should return the number of arithmetic slices in the array A.

Example:

A = [1, 2, 3, 4]return: 3, for 3 arithmetic slices in A: [1, 2, 3], [2, 3, 4] and [1, 2, 3, 4] itself.

解题思路:

题目描述的很明确,包含至少三个数的序列,如果差分相等,那么这个序列就叫做arithmetic sequence,在一个数组里统计有多少个满足条件的序列(切片)。首先试试暴力法。我们固定一个最小长度为3的区间(i, j),如果差分相等,我们就右移j,一直到数组的末尾,满足条件的话计数加一。需要注意的是如果区间(i, j-1)是arithmetic slice,那么我们末尾加上一个j,如果A[j] - A[j-1] 等于之前的差分值,那么区间(i, j)也属于arithmetic slice,我们要避免每次判断都要计算前面的差分。代码如下:

class Solution(object):def numberOfArithmeticSlices(self, A):res = 0for i in range(len(A)-2):d = A[i+1] - A[i]for j in range(i+2, len(A)):if A[j] - A[j-1] == d:res += 1else:breakreturn res

 当然我们可以用dp算法,令一维dp[i]表示以i结尾的区间有多少个arithmetic  slice,新添加的元素和前面元素的差,如果等于之前的差值,那么就让dp[i]加一。代码如下:

class Solution(object):def numberOfArithmeticSlices(self, A):dp = [0 for i in range(len(A))]res = 0for i in range(2, len(A)):if A[i] - A[i-1] == A[i-1] - A[i-2]:dp[i] = 1 + dp[i-1]res += dp[i]return res

我们可以优化空间复杂度,因为dp的更新只跟上一个元素有关,因此我们用一个变量空间来代替原来的数组。

class Solution(object):def numberOfArithmeticSlices(self, A):dp = 0res = 0for i in range(2, len(A)):if A[i] - A[i-1] == A[i-1] - A[i-2]:dp += 1res += dpelse:dp = 0return res

 



转载于:https://www.cnblogs.com/nicotine1026/p/7459989.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/280632.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在Data Lake Analytics中使用视图

在Data Lake Analytics中使用视图 1. 概述 在Data Lake Analytics&#xff08;以下简称DLA&#xff09;中使用视图&#xff08;VIEW&#xff09;功能&#xff0c;可以大大简化对于重复SQL&#xff0c;特别是较为复杂的SQL语句的编写和维护。目前DLA中还不支持SQL视图的物化。在…

C# 实例详解委托之Func、Action、delegate(精品)

概述委托是.NET编程的精髓之一&#xff0c;在日常编程中经常用到&#xff0c;在C#中实现委托主要有Func、Action、delegate三种方式&#xff0c;本节主要就这三种委托的用法通过实例展开讲解。Func用法解析【Func】&#xff1a;Func是带返回值的委托&#xff1a;原型函数如下(以…

Django05-2:路由分发/命名空间/伪静态/虚拟环境/django版本区别

路由分发 补充&#xff1a;每一个应用可以有独立的templates模板文件夹&#xff0c;static静态文件加&#xff0c;urls.py 总路由 #方法一from app01 import urls as app01_urls from app02 import urls as app02_urlsurlpatterns [url(r^publisher_list/, views.publisher_…

Word中查找替换软回车键和回车键

在Word中使用搜索功能搜索“^p”组合字符串可以查找文档中的所有换行符&#xff08;回车键&#xff09;&#xff0c;使用“^l”&#xff08;英文输入状态下shift6与小写字符L的组合&#xff09;可以搜索所有的软回车符。使用替换功能就可以搜索替换二者。转载于:https://www.cn…

minecraft服务器_如何使用Minecraft领域设置简单的无压力Minecraft服务器

minecraft服务器There are a lot of ways to go about hosting a Minecraft game but it’s tough to beat the simplicity of buying a server directly from Mojang, the company behind Minecraft (and now it even comes with a free 30 day trial!) Read on as we show yo…

自动化测试基础篇--Selenium浏览器操作

Selenium 主要提供的是操作页面上各种元素的方法&#xff0c;但它也提供了操作浏览器本身的方法&#xff0c;比如浏览器的大小以及浏览器后退、前进按钮等。一、控制浏览器窗口大小有时候我们希望能以某种浏览器尺寸打开&#xff0c;让访问的页面在这种尺寸下运行。例如可以将浏…

Sublime text3配置xdebug调试记录

第一次配置遇到的问题记录&#xff1b; 问题&#xff1a;配置php.ini的时候xdebug.remote_port 9001刚开始我一直配置9000端口冲突,然后一切弄好了访问浏览器就一直在转圈无法访问&#xff1b; 现在开始配置&#xff1a; 1.打开sublime 输入install Package如下显示在按回车&a…

.NET Conf China 2022 今天(12.4) 日程一览

点击蓝字关注我们.NET Conf China 2022 诚邀您的加入立即扫码预约加入.NET年度盛宴&#xff01;&#xff01;CSDN 直播https://bbs.csdn.net/forums/DotNET?typeId20680 思否直播https://segmentfault.com/area/dotnetconf-2022主论坛分论坛前端专场-A会场出品人&#xff1a;张…

移动web开发适配rem

移动的meta标签 <meta name"viewport" content"widthdevice-width, initial-scale1,user-scalableno"> 常见移动web适配方法&#xff1a; 1.定高&#xff0c;百分比布局 2.flex布局 3.media媒体查询 rem&#xff08;font size of the root element…

Django06:视图层/上传文件/request 方法补充/FBV与CBV

三板斧 HttpResponse, 返回字符串类型render, 返回html页面&#xff0c;而且在返回给浏览器之前&#xff0c;可以给html文件传值redirect 重定向 总结&#xff1a;视图函数必须返回一个HttpResponse对象&#xff0c; 查看源代码能发现。 JsonResponse对象 json用途&#x…

《Java核心技术 卷Ⅱ 高级特性(原书第10版)》一2.4.6 为克隆使用序列化

2.4.6 为克隆使用序列化 序列化机制有一种很有趣的用法&#xff1a;即提供了一种克隆对象的简便途径&#xff0c;只要对应的类是可序列化的即可。其做法很简单&#xff1a;直接将对象序列化到输出流中&#xff0c;然后将其读回。这样产生的新对象是对现有对象的一个深拷贝&…

谈谈ASP.NET Core过滤器和中间件的区别

什么是中间件中间件Middleware是所有请求都会执行的,适合用在权限校验,一些公用字段处理,例如分页信息获取.asp.net core 提供了IApplicationBuilder接口来让把中间件注册到asp.net的管道请求当中去&#xff0c;中间件是一个典型的AOP应用。下面是一个微软官方的一个中间件管道…

11 个 Nginx 参数性能优化工作

工作上&#xff0c;需要配置 Nginx&#xff0c;要投入生产使用&#xff0c;做了一点优化工作&#xff0c;加上以前也经常折腾 Nginx&#xff0c;故记下一些优化工作。 优化 Nginx 进程数量 配置参数如下&#xff1a; worker_processes 1; # 指定 Nginx 要开启的进程数&#xff…

如何在Windows 8中将旧控制面板添加到Metro Start屏幕

By default there is no way to easily access the old Control Panel in Windows 8, in order to get to it you have to go through the new Metro Control Panel or switch to Explorer. Here’s how to create your own tile for it. 默认情况下&#xff0c;无法轻松访问Wi…

vue子父组件间传值

父组件传值给子组件 props方式   父组件上1处声明传递的键并赋值&#xff0c;子组件2处使用props接收一下这个键就可以使用了。在父组件改变这个值的话子组件跟着一起响应&#xff0c;子组件改变这个值的话父组件不改变。次为响应式&#xff0c;但是也仅限于父组件的值变化子…

Django07:模板语法/标签/inclusion_tag/模版的继承

模板语法传值 列表&#xff1a;l[a,b,c] 集合&#xff1a;se{‘a’,yy,ss} 元组&#xff1a;t(111,222,333) render(request.index,html,locals()) 语法规律 {{}}:变量相关 {%%}:逻辑相关 {{func}} 会自动加括号执行&#xff0c;但不支持带参数&#xff1b; 带参数会不…

红象云腾发布新一代PB级高速大数据平台产品

ZD至顶网服务器频道 03月23日 新闻消息&#xff1a;在3月19日举办的China Hadoop Summit&#xff08;中国Hadoop技术峰会&#xff09;上&#xff0c;中国Hadoop大数据厂商红象云腾与OpenPOWER基金会共同发布红象云腾的新一代大数据产品,帮助企业高速处理PB规模数据。 此次发布…

个人笔记 Vue.js, Framework7, and Cordova / PhoneGap Template with Babel, Webpack and Hot Reloading...

为什么80%的码农都做不了架构师&#xff1f;>>> 模板创建项目 模板地址 更新package.json中的dependencies依赖到最新版本 当新建一个项目的时候&#xff0c;从其他项目的package.json里面copy一份dependencies过来。 但因为是新项目&#xff0c;我们想用各个依赖包…

dotnet-exec 0.12.0 released

dotnet-exec 0.12.0 releasedIntrodotnet-exec 是一个 C# 程序的小工具&#xff0c;可以用来运行一些简单的 C# 程序而无需创建项目文件&#xff0c;让 C# 像 python/nodejs 一样简单&#xff0c;而且可以自定义项目的入口方法&#xff0c;支持但不限于 Main 方法。Install/Upd…

美国用户现在可以下载其所有Apple帐户数据,这是操作方法

Starting today, Apple is allowing all US users to download a copy of every last bit of their data from the company. 从今天开始&#xff0c;Apple允许所有美国用户从该公司下载其数据的最后一部分的副本。 This feature has been available for EU users since May, th…