判断子序列


文章目录


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

一、题目

给定一个长度为 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.

相关推荐
艾莉丝努力练剑29 分钟前
【Linux基础开发工具 (三)】Vim从入门到精通(下):效率翻倍的编辑技巧与个性化配置攻略
linux·运维·服务器·c++·ubuntu·centos·vim
yuuki23323333 分钟前
【数据结构】栈
c语言·数据结构·后端
草莓熊Lotso34 分钟前
C++ STL set 系列完全指南:从底层原理、核心接口到实战场景
开发语言·c++·人工智能·经验分享·网络协议·算法·dubbo
咖啡の猫2 小时前
搭建Python开发环境
开发语言·python
做怪小疯子3 小时前
LeetCode 热题 100——子串——和为 K 的子数组
算法·leetcode·职场和发展
zl_vslam4 小时前
SLAM中的非线性优-3D图优化之李群李代数在Opencv-PNP中的应用(四)
人工智能·opencv·算法·计算机视觉
程序猿小蒜4 小时前
基于springboot的共享汽车管理系统开发与设计
java·开发语言·spring boot·后端·spring·汽车
听风吟丶5 小时前
Java 8 Stream API 高级实战:从数据处理到性能优化的深度解析
开发语言·python
hygge9995 小时前
Spring Boot + MyBatis 整合与 MyBatis 原理全解析
java·开发语言·经验分享·spring boot·后端·mybatis
AA陈超6 小时前
ASC学习笔记0014:手动添加一个新的属性集
c++·笔记·学习·ue5