判断子序列


文章目录


提示:以下是本篇文章正文内容

一、题目

给定一个长度为 n

的整数序列 a1,a2,...,an

以及一个长度为 m

的整数序列 b1,b2,...,bm

请你判断 a

序列是否为 b

序列的子序列。

子序列指序列的一部分项按原有次序排列而得的序列,例如序列 {a1,a3,a5}

是序列 {a1,a2,a3,a4,a5}

的一个子序列。

输入格式

第一行包含两个整数 n,m

第二行包含 n

个整数,表示 a1,a2,...,an

第三行包含 m

个整数,表示 b1,b2,...,bm

输出格式

如果 a

序列是 b

序列的子序列,输出一行 Yes。

否则,输出 No。

数据范围

1≤n≤m≤105

,

−109≤ai,bi≤109

输入样例:

3 5

1 3 5

1 2 3 4 5

输出样例:

Yes

二、思路及代码

1.思路

双指针的思想。

2.答案

代码如下:

c 复制代码
#include <iostream>
#include <cstring>
#include <algorithm>

using namespace std;

const int N = 100010;

int a[N], b[N];

int main()
{
    int n, m;
    cin >> n >> m;
    
    for(int i = 0; i < n; i ++) cin >> a[i];
    
    for(int i = 0; i < m; i ++) cin >> b[i];
    
    int i, j;
    for(i = 0, j = 0; i < n && j < m; j ++)
        if(a[i] == b[j]) i ++;
    
    if(i == n) cout << "Yes" << endl;
    else cout << "No" << endl;
    
    return 0;
}

总结

Just Review.

相关推荐
小郭团队14 分钟前
1_6_五段式SVPWM (传统算法反正切+DPWM2)算法理论与 MATLAB 实现详解
嵌入式硬件·算法·matlab·dsp开发
小郭团队21 分钟前
1_7_五段式SVPWM (传统算法反正切+DPWM3)算法理论与 MATLAB 实现详解
开发语言·嵌入式硬件·算法·matlab·dsp开发
鱼跃鹰飞24 分钟前
Leetcode347:前K个高频元素
数据结构·算法·leetcode·面试
bybitq26 分钟前
LeetCode236-二叉树的最近公共祖先(LCA)问题详解-C++
算法·深度优先
C+-C资深大佬42 分钟前
C++风格的命名转换
开发语言·c++
啊阿狸不会拉杆42 分钟前
《数字图像处理》第 7 章 - 小波与多分辨率处理
图像处理·人工智能·算法·计算机视觉·数字图像处理
No0d1es44 分钟前
2025年粤港澳青少年信息学创新大赛 C++小学组复赛真题
开发语言·c++
点云SLAM1 小时前
C++内存泄漏检测之手动记录法(Manual Memory Tracking)
开发语言·c++·策略模式·内存泄漏检测·c++实战·new / delete
好评1241 小时前
【C++】二叉搜索树(BST):从原理到实现
数据结构·c++·二叉树·二叉搜索树
zylyehuo1 小时前
error: no matching function for call to ‘ros::NodeHandle::param(const char [11], std::string&, const char [34])’
c++·ros1