三.双指针/链表/数组模板

00. AcWing双指针模板:寻找单调性

# j <= i
i = 0; j = 0
while i < n:
    while j < i and check(i, j): j += 1
    # 具体问题的逻辑
	i += 1

# 其实就是后一章的滑动窗口模板,滑动窗口是双指针的特殊情况。
# 双指针问题先写出暴力解法,再根据单调性寻找优化
# 常见问题分类:
# (1) 对于一个序列,用两个指针维护一段区间
# (2) 对于两个序列,维护某种次序,比如归并排序中合并两个有序序列的操作
# O(n*n) -> O(n)

活动 - AcWing

def main():
    a = [0] * 100010
    s = [0] * 100010
    n = int(input())
    a = list(map(int, input().split(' ')))
    res = 0
    i = 0; j = 0
    
    while i < n:
        s[a[i]] += 1
        while j <= i and s[a[i]] > 1:
            s[a[j]] -= 1
            j += 1
        res = max(res, i - j + 1)
        i += 1
            
    print(res)    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值