顺序表公共元素查找 【问题描述】给定两个顺序表,编写算法找出两表的公共结点。 【输入形式】 四行: 第一行:一个数字(第一个顺序表中的元素个数) 第二行:第一个顺序表中各个结点的值 第三行:一个数字(第二个顺序表中的元素个数) 第四行:第二个顺序表中各个结点的值 【输出形式】 两行: 第一行:两个单链表的公共元素个数 第二行:依次打印输出各个公共元素 编写C++代码
时间: 2024-02-15 17:01:32 浏览: 104
好的,以下是我的 C++ 代码实现:
```c++
#include <iostream>
#include <vector>
using namespace std;
// 定义顺序表类
class SqList {
public:
SqList(int* lst, int len) {
data = new int[len];
length = len;
for (int i = 0; i < length; i++) {
data[i] = lst[i];
}
}
~SqList() {
delete[] data;
}
int* data; // 数据
int length; // 长度
};
// 查找两个顺序表的公共元素
vector<int> find_common_elements(SqList* l1, SqList* l2) {
int p1 = 0, p2 = 0; // 两个顺序表的指针
vector<int> common_elements; // 公共元素列表
while (p1 < l1->length && p2 < l2->length) {
if (l1->data[p1] == l2->data[p2]) {
common_elements.push_back(l1->data[p1]);
p1++;
p2++;
}
else if (l1->data[p1] < l2->data[p2]) {
p1++;
}
else {
p2++;
}
}
return common_elements;
}
int main() {
int n1, n2;
cin >> n1;
int* lst1 = new int[n1];
for (int i = 0; i < n1; i++) {
cin >> lst1[i];
}
cin >> n2;
int* lst2 = new int[n2];
for (int i = 0; i < n2; i++) {
cin >> lst2[i];
}
// 创建两个顺序表
SqList* L1 = new SqList(lst1, n1);
SqList* L2 = new SqList(lst2, n2);
// 查找公共元素
vector<int> common_elements = find_common_elements(L1, L2);
// 输出结果
cout << common_elements.size() << endl;
for (int i = 0; i < common_elements.size(); i++) {
cout << common_elements[i] << " ";
}
cout << endl;
// 释放内存
delete[] lst1;
delete[] lst2;
delete L1;
delete L2;
return 0;
}
```
这段代码与之前的 Python 代码类似,实现了一个查找两个顺序表公共元素的函数 `find_common_elements`,并且根据题目要求,从输入中读取两个顺序表的元素并创建两个顺序表对象 `L1` 和 `L2`,最后调用该函数查找公共元素并输出结果。需要注意的是,由于 C++ 不支持动态数组,需要手动分配和释放内存。
阅读全文