【蓝桥杯国赛】双指针

适用于以下的情境:

① 数组 / 字符串中,有多少个满足情况的连续区间。

② 数组 / 字符串,合并。


【第十三届pythonB组试题:近似gcd】

1. 题目描述

2. 难度:⭐⭐⭐⭐

3. 思考分析:

具体参考:第十三届蓝桥杯国赛 C++ C组 F 题、Python B组 E 题------近似GCD(AC)_蓝桥杯python,bc组的题一样吗?-CSDN博客

① tmp 记录上一个不满足条件的数的位置。

② 设置 right 作为区间到达的最远处;若碰到不满足情况的数字,指针 left=tmp+1,使其始终满足"每个区间内至多一个不满足条件的数字"。

③该区间的长度,即为区间的数目。

复制代码
import math

n, g = map(int, input().split())
ans = list(map(int, input().split()))

res = 0
tmp = -1 #记录上一个不符合条件的数
left, right = 0, 0
for right in range(n):
    t = math.gcd(g, ans[right])
    #自始至终只能保证有一个不符合条件的数在区间内
    if t!=g:
        left = tmp + 1
        tmp = right
    if right-left+1>=2:
        res += right - left
print(res)

【第十届JavaB组试题:最长子序列】

1. 题目描述

2. 难度:⭐

3. 思考分析:

分别用 a, b 两个指针指向两个字符串,当满足相等情况时,才接着向后移动。

复制代码
s = input()
t = input()

a=0;b=0
ans = 0
while a<len(s) and b<len(t):
    if s[a]==t[b]:
        a += 1
        b += 1
        ans += 1
    else:
        a +=1
print(ans)

【第十四届C/C++B组试题:合并数列】

1. 题目描述

2. 难度:⭐⭐⭐

3. 思考分析

①利用**"双指针"**时,不要改变指针指向的数组的内容;而是选择另一个衡量标准------"当前的数组和是否相等"。

②当使用**"while循环"**时,需格外注意其循环条件:有可能p==n-1,但此时q!=(m-1)且sumA!=sumB。但两个数组的数组和必然是相等的,因此只需要再合并数组余下的数即可。

复制代码
n, m = map(int, input().split())
a = list(map(int, input().split()))
b = list(map(int, input().split()))

p=0;q=0
sumA=0;sumB=0
ans = 0
while p<n and q<m:
    if sumA==sumB:
        sumA += a[p]
        sumB += b[q]
        p+=1;q+=1
    elif sumA<sumB:
        sumA += a[p]
        p += 1
        ans += 1
    elif sumA>sumB:
        sumB += b[q]
        q += 1
        ans += 1
if p==n and q==m:
    print(ans)
else:
    print(ans+(n-p)+(m-q))
相关推荐
计算机学姐2 小时前
基于微信小程序的高校班务管理系统【2026最新】
java·vue.js·spring boot·mysql·微信小程序·小程序·mybatis
一路向北⁢2 小时前
基于 Apache POI 5.2.5 构建高效 Excel 工具类:从零到生产级实践
java·apache·excel·apache poi·easy-excel·fast-excel
毕设源码-赖学姐5 小时前
【开题答辩全过程】以 基于Android的校园快递互助APP为例,包含答辩的问题和答案
java·eclipse
damo015 小时前
stripe 支付对接
java·stripe
麦麦鸡腿堡6 小时前
Java的单例设计模式-饿汉式
java·开发语言·设计模式
假客套6 小时前
Request method ‘POST‘ not supported,问题分析和解决
java
傻童:CPU6 小时前
C语言需要掌握的基础知识点之前缀和
java·c语言·算法
爱吃山竹的大肚肚6 小时前
@Valid校验 -(Spring 默认不支持直接校验 List<@Valid Entity>,需用包装类或手动校验。)
java·开发语言
雨夜之寂7 小时前
mcp java实战 第一章-第一节-MCP协议简介.md
java·后端
皮皮林5517 小时前
蚂蚁又开源了一个顶级 Java 项目!
java