判断子序列(双指针)一图搞定

举报
irrational 发表于 2022/01/17 23:34:45 2022/01/17
【摘要】 给定一个长度为 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序列的子序列。子序列指序列的一部分项按原有次序排列而得的序列,例如序列 {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,
−10^9≤ai,bi≤10^9

输入样例:


  
  1. 3 5
  2. 1 3 5
  3. 1 2 3 4 5

输出样例:

Yes

 


  
  1. #include <iostream>
  2. #include <cstring>
  3. using namespace std;
  4. const int N = 100010;
  5. int n, m;
  6. int a[N], b[N];
  7. int main()
  8. {
  9. scanf("%d%d", &n, &m);
  10. for (int i = 0; i < n; i ++ ) scanf("%d", &a[i]);
  11. for (int i = 0; i < m; i ++ ) scanf("%d", &b[i]);
  12. int i = 0, j = 0;
  13. while (i < n && j < m)
  14. {
  15. if (a[i] == b[j]) i ++ ;
  16. j ++ ;
  17. }
  18. if (i == n) puts("Yes");
  19. else puts("No");
  20. return 0;
  21. }

直接两个数组两个指针分别匹配就可了。

(PS:由于CSDN每天只能发10篇,太限制小伙伴的想象了,大家可以访问我的cnblog:博客园

文章来源: blog.csdn.net,作者:irrationality,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/weixin_54227557/article/details/120596540

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。