LeetCode 1566. 重复至少 K 次且长度为 M 的模式

文章目录

    • 1. 题目
    • 2. 解题

1. 题目

给你一个正整数数组 arr,请你找出一个长度为 m 且在数组中至少重复 k 次的模式。

模式 是由一个或多个值组成的子数组(连续的子序列),连续 重复多次但 不重叠 。 模式由其长度和重复次数定义。

如果数组中存在至少重复 k 次且长度为 m 的模式,则返回 true ,否则返回 false 。

示例 1:
输入:arr = [1,2,4,4,4,4], m = 1, k = 3
输出:true
解释:模式 (4) 的长度为 1 ,且连续重复 4 次。
注意,模式可以重复 k 次或更多次,但不能少于 k 次。示例 2:
输入:arr = [1,2,1,2,1,1,1,3], m = 2, k = 2
输出:true
解释:模式 (1,2) 长度为 2 ,且连续重复 2 次。
另一个符合题意的模式是 (2,1) ,同样重复 2 次。示例 3:
输入:arr = [1,2,1,2,1,3], m = 2, k = 3
输出:false
解释:模式 (1,2) 长度为 2 ,但是只连续重复 2 次。
不存在长度为 2 且至少重复 3 次的模式。示例 4:
输入:arr = [1,2,3,1,2], m = 2, k = 2
输出:false
解释:模式 (1,2) 出现 2 次但并不连续,所以不能算作连续重复 2 次。示例 5:
输入:arr = [2,2,2,2], m = 2, k = 3
输出:false
解释:长度为 2 的模式只有 (2,2) ,但是只连续重复 2 次。
注意,不能计算重叠的重复次数。提示:
2 <= arr.length <= 100
1 <= arr[i] <= 100
1 <= m <= 100
2 <= k <= 100

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/detect-pattern-of-length-m-repeated-k-or-more-times
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

class Solution {
public:bool containsPattern(vector<int>& arr, int m, int k) {int n = arr.size(), i, j, len, count;if(m*k > n) return false;//长度不够for(int l = 0; l <= n-m*k; ++l) //枚举起点{count = 1, i = l, j = l+m, len = m;while(j < n && count < k){if(arr[j] == arr[i])i++,j++;elsebreak;if(i == l+m)//满足了一个模式i = l, count++;//计数,i回到起点}if(count >= k)return true;}return false;}
};

0 ms 8.1 MB


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
Michael阿明

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

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

相关文章

R语言的安装与配置

一、什么是 R 语言 R 编程语言被广泛应用在统计科学和商业领域。 在各种编程语言排名中 R 语言的排名都很靠前。 它是一款集成了数据操作、统计&#xff0c;以及可视化功能的优秀开源软件。免费&#xff0c;开源是 R 重要的特点。 二、什么是 RStudio RStudio 是用亍 R 编程的…

python中的多线程-共享全局变量

在一个进程内的所有线程共享全局变量&#xff0c;能够在不适用其他方式的前提下完成多线程之间的数据共享&#xff08;这点要比多进程要好&#xff09; 缺点就是&#xff0c;线程是对全局变量随意遂改可能造成多线程之间对全局变量的混乱&#xff08;即线程非安全&#xff09; …

R语言第一讲

一、R语言入门推荐 推荐四本材料书&#xff1a;R CookBook &#xff1a;hhtp&#xff1a;//www.cookbook-r.com/R in Action http://www.amazon.com/R-Action-Robert-Kabaccoff/dp/1935182390Ggplot2:Elegant Graphics for Data Analysis(User R):hhtp://www.amazon.com/ggplo…

LeetCode 1567. 乘积为正数的最长子数组长度

文章目录1. 题目2. 解题1. 题目 给你一个整数数组 nums &#xff0c;请你求出乘积为正数的最长子数组的长度。 一个数组的子数组是由原数组中零个或者更多个连续数字组成的数组。 请你返回乘积为正数的最长子数组长度。 示例 1&#xff1a; 输入&#xff1a;nums [1,-2,-…

python中的互斥锁

如果没有控制多个线程对同一资源的访问&#xff0c;对数据造成破坏&#xff0c;使得线程运行的结果不可预期。这种现象称为“线程不安全”。 线程同步解决问题: 系统调用t1&#xff0c;然后获取到num的值为0&#xff0c;此时上一把锁&#xff0c;即不允许其他现在操作num 对nu…

R语言第二讲

1、R语言包的概念 R提供了大量开箱即用的功能&#xff0c;但它最激动人心的一部分功能是通过可选模块的下载和安装 来实现的。目前有2500多个①称为包&#xff08;package&#xff09;的用户贡献模块可从 http://cran.r-project.org/ web/packages 下载。这些包提供了横跨各种…

LeetCode 1568. 使陆地分离的最少天数(DFS)

文章目录1. 题目2. 解题1. 题目 给你一个由若干 0 和 1 组成的二维网格 grid &#xff0c;其中 0 表示水&#xff0c;而 1 表示陆地。 岛屿由水平方向或竖直方向上相邻的 1 &#xff08;陆地&#xff09;连接形成。 如果 恰好只有一座岛屿 &#xff0c;则认为陆地是 连通的 &…

python中的非阻塞使用互斥锁

锁定方法acquire可以有一个blocking参数。 如果设定blocking为True&#xff0c;则当前线程会堵塞&#xff0c;直到获取到这个锁为止&#xff08;如果没有指定&#xff0c;那么默认为True&#xff09; 如果设定blocking为False&#xff0c;则当前线程不会堵塞 from threading im…

在XML文件中定义动画(1)

① 打开Eclipse&#xff0c;新建Android工程② 在res目录中新建anim文件夹③ 在anim目录中新建一个myanim.xml(注意文件名小写)④ 加入XML的动画代码 <?xml version"1.0" encoding"utf-8"?><set xmlns:android"http://schemas.android…

LeetCode 1569. 将子数组重新排序得到同一个二叉查找树的方案数(DP)

文章目录1. 题目2. 解题1. 题目 给你一个数组 nums 表示 1 到 n 的一个排列。 我们按照元素在 nums 中的顺序依次插入一个初始为空的二叉查找树&#xff08;BST&#xff09;。 请你统计将 nums 重新排序后&#xff0c;统计满足如下条件的方案数&#xff1a;重排后得到的二叉查…

ADS1.2开发环境创建与简要介绍

ADS1.2下建立工程 1.运行ADS1.2集成开发环境&#xff08;CodeWarrior for ARM Developer Suite&#xff09;&#xff0c;点击File|New,在New对话框中&#xff0c;选择Project栏&#xff0c;其中共有7项&#xff0c;ARM Executable Image是ARM的通用模板。选中它即可生成ARM的执…

多线程的全局变量与局部变量

在多线程开发中&#xff0c;全局变量是多个线程都共享的数据&#xff0c;而局部变量等是各自线程的&#xff0c;是非共享的。 from threading import Thread import time classMyThread(Thread): # 重写 构造方法 def __init__(self, num): # Thread.__init__(self) super(MyT…

const类型成员函数与mutable

const类型成员函数与mutable 原文&#xff1a;http://houhualiang.i.sohu.com/blog/view/42619368.htm const类型的成员函数是指使用const关键字进行修饰的类的成员函数。const类型的成员函数对函数内部的操作加以一定的限制&#xff0c;比如不可以对对象的属性进行修改等&…

阿里云 超级码力在线编程大赛初赛 第2场 题目1. 三角魔法

文章目录1. 题目2. 解题1. 题目 题目来源&#xff1a;https://tianchi.aliyun.com/oj/15165469968503404/76745683722506851 2. 解题 采用直线的一般式进行判定 首先要能组成三角形然后是我的位置和第3点在另外两点形成的直线同侧 class Solution { public:/*** param tria…

R语言第四讲 之R语言数据类型

基本类型 通常&#xff0c;在使用任何编程语言进行编程时&#xff0c;您需要使用各种变量来存储各种信息。 变量只是保留值的存储位置。 这意味着&#xff0c;当你创建一个变量&#xff0c;你必须在内存中保留一些空间来存储它们。 您可能想存储各种数据类型的信息&#xff0…

python中的死锁

在线程间共享多个资源的时候&#xff0c;如果两个线程分别占有一部分资源并且同时等待对方的资源&#xff0c;就会造成死锁。 尽管死锁很少发生&#xff0c;但一旦发生就会造成应用的停止响应。下面看一个死锁的例子 from threading import Thread, Lock import time mutex1 …

linux 编译安装apache

1、下载apache、安装apache #wget http://apache.etoak.com//httpd/httpd-2.4.4.tar.gz #tar zxvf httpd-2.4..4.tar.gz2. 安装apache 之前要先安装 apr 和 apr-util apr 下载地址 http://apr.apache.org/download.cgi # wget http://mirrors.cnnic.cn/apache//apr/apr-1…

阿里云 超级码力在线编程大赛初赛 第2场 题目3. 五字回文

文章目录1. 题目2. 解题1. 题目 来源&#xff1a;https://tianchi.aliyun.com/oj/15165469968503404/76745683722506852 2. 解题 注意 a,b,c互不相同 class Solution { public:/*** param s: The given string* return: return the number of Five-character palindrome*/in…

R语言第五讲 之R语言 变量

概述 变量为我们提供了我们的程序可以操作的命名存储。 R语言中的变量可以存储原子向量&#xff0c;原子向量组或许多Robject的组合。 有效的变量名称由字母&#xff0c;数字和点或下划线字符组成。 变量名以字母或不以数字后跟的点开头。 变量名合法性原因var_name2.有效有字…

python中解决死锁的方法

1.添加超时时间&#xff1a; fromthreading import Thread, Lock importtime mutex1 Lock() # 创建一个互斥锁 mutex2 Lock() # 创建一个互斥锁 def fun1(): while True: mutex1.acquire() print("线程1 锁住了mutex1") time.sleep(0.1) result mutex2.acquire(…