双指针扫描

编程入门 行业动态 更新时间:2024-10-24 07:22:17

双<a href=https://www.elefans.com/category/jswz/34/1768268.html style=指针扫描"/>

双指针扫描

import os
import sys# 请在此输入您的代码
s=input()
A=list(s)
n=len(A)
t=1
for i in range(n//2):if A[i]!=A[n-1-i]:t=0break
if t==1:print('Y')
else:print('N')
n,s=map(int,input().split())
a=list(map(int,input().split()))
#尺取法,变O(n*n)为O(n)
#维护一个最短的区间
ans=1e8
sum=0
i,j=0,0
while i<n:if sum<s:sum+=a[i]i+=1else:ans=min(ans,(i-j))sum-=a[j]j+=1
if ans==1e8:print(0)
# 朴素做法(用于对比):
for i in range(n):for j in range(i):if check(j, i):res = max(res, j - i + 1)# 双指针做法:
for j in range(n):while i <= j and check(i, j):		# check函数根据题意编写i += 1res = max(res, j - i + 1)

 

更多推荐

双指针扫描

本文发布于:2023-11-17 00:19:39,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1634441.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:指针

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!