已知两个由正整数组成的无序序列A、B,每个序列的元素个数未知,但至少有一个元素。你的任务是判断序列B是否是序列A的连续子序列。假设B是“1 9 2 4 18”,A是“33 64 1 9 2 4 18 7”,B是A的连续子序列;假设B是“1 9 2 4 18”,A是“33 1 9 64 2 4 18 7”,B不是A的连续子序列。
输入格式:
依次输入两个乱序的正整数序列A、B,序列中元素个数未知,但每个序列至少有一个元素,并以输入“-1”结束(-1不算序列中元素),每个序列占一行。两个数列的长度均不超过1000。
输入保证合法,且所有整数均可用int存储。
输出格式:
如果序列B是序列A的连续子序列,则输出“ListB is the sub sequence of ListA.”,否则输出“ListB is not the sub sequence of ListA.”。
输入样例:
5 4 3 2 1 -1
3 2 1 -1
输出样例:
ListB is the sub sequence of ListA.
MY IDEAS:
1.首先是一道数组题,元素数量未知,所以按题目给的最大长度来定义数组。
2. for (i=0;A[i-1]!=-1;i++)
{
scanf("%d",&A[i]);
}
这一步在判断时需要对i再减1,因为是先加一,再去判断是否符合循环要求。
3.自己在定义变量的时候总是会乱,要做好标记,同时自己形成自己的习惯。
4.我通过对A[]进行循环,和B[0]BI比较,如果相等,就进入判断,且pass=0

这篇博客讨论了一道关于判断两个无序正整数序列的问题,目标是确定序列B是否为序列A的连续子序列。博主分享了解题思路,包括如何读取数组、遍历序列以及判断连续子序列的条件。博客强调了在编程过程中遇到困难时应保持冷静,通过反复思考和优化解决问题。
最低0.47元/天 解锁文章
1107

被折叠的 条评论
为什么被折叠?



