
本关任务: 将直接插入排序、直接选择排序、冒泡排序、顺序查找函数封装到数组类 Array 中,作为成员函数。
为了完成本关任务,你需要掌握:
直接插入排序:
void insertionSort(int arr[], int n) {
for (int i = 1; i < n; i++) {
int key = arr[i];
int j = i - 1;
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j];
j--;
}
arr[j + 1] = key;
}
}直接选择排序:
void selectionSort(int arr[], int n) {
for (int i = 0; i < n - 1; i++) {
int minIndex = i;
for (int j = i + 1; j < n; j++) {
if (arr[j] < arr[minIndex]) {
minIndex = j;
}
}
if (minIndex!= i) {
int temp = arr[i];
arr[i] = arr[minIndex];
arr[minIndex] = temp;
}
}
}冒泡排序:
void bubbleSort(int arr[], int n) {
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}顺序查找:
int sequentialSearch(int arr[], int n, int target) {
for (int i = 0; i < n; i++) {
if (arr[i] == target) {
return i;
}
}
return -1; // 表示未找到目标元素
}类的基本结构:
class Array {
private:
int* data; // 可以用来存储数组元素的指针,这里假设存储整数数组
int size; // 数组的大小
public:
Array(int arr[], int n); // 构造函数声明,用于初始化数组对象
// 在这里声明要封装的排序和查找成员函数,如
void insertionSort();
void selectionSort();
void bubbleSort();
int sequentialSearch(int target);
};Array 类,包括类的声明部分(一般在 .h 文件中定义类的成员变量和成员函数的声明)和类的实现部分(一般在 .cpp 文件中实现成员函数的具体代码逻辑)。例如:成员函数的定义与调用:
要掌握如何在类的实现文件中正确地定义这些成员函数,并且在函数内部能够正确地访问类的私有成员变量(如通过 this 指针来访问当前对象的 data 和 size 等成员)。例如,插入排序成员函数在类中的实现大致如下:
void Array::insertionSort() {
for (int i = 1; i < this->size; i++) {
int key = this->data[i];
int j = i - 1;
while (j >= 0 && this->data[j] > key) {
this->data[j + 1] = this->data[j];
j--;
}
this->data[j + 1] = key;
}
}同时,要清楚如何在类外部创建 Array 类的对象,并调用这些封装好的成员函数来对数组进行相应的排序或查找操作,比如:
int main() {
int arr[] = {5, 3, 4, 6, 2};
Array myArray(arr, 5);
myArray.insertionSort();
// 可以继续调用其他排序或查找成员函数进行相应操作
return 0;
}内存管理方面:
data 指针成员),要考虑数组内存的分配与释放问题。在构造函数中,可能需要根据传入的数组大小动态分配内存来存储数组元素(一般使用 new 关键字),在类的析构函数中,要记得释放之前分配的内存(使用 delete[] 关键字),避免内存泄漏。例如:Array::Array(int arr[], int n) {
this->size = n;
this->data = new int[n];
for (int i = 0; i < n; i++) {
this->data[i] = arr[i];
}
}
Array::~Array() {
delete[] this->data;
}正确访问数组元素:
this->data[i] 的形式来访问数组中第 i 个元素,确保操作的是当前对象所关联的数组内容。4. 函数参数传递与返回值处理
综上所述,掌握以上这些知识要点,就可以顺利地将相关排序和查找函数封装到 Array 类中作为成员函数了。
在右侧编辑器补充代码,实现 3 种排序算法。
平台会对你编写的代码进行测试:
测试输入: 无;
预期输出: 1 2 3 6 8 1.9 3.2 4.1 5.6 A c g 2 -1
开始你的任务吧,祝你成功!
#include <iostream>
using namespace std;
template <class T>
class Array
{
T* alist;
int size;
public:
Array() {size = 0;}
Array(int sz) {alist = new T[sz]; size = sz;}
Array(T a[], int sz) {
size = sz;
alist = new T[size];
for (int i = 0; i < size; i ++)
alist[i] = a[i];
}
~Array() {size = 0; delete []alist;}
int getSize() {return size;}
T& operator [](int i) {return alist[i];}
void output(){
for(int i = 0; i < size; i ++)
cout << alist[i] << " ";
cout << endl;
}
void insertSort();
void selectSort();
void bubbleSort();
int seqSearch(T key);
};
/********** Begin **********/
// 在数组中顺序查找第一个key元素,若找到则返回其索引值(是数组中第几个,从0算起),找不到则返回-1
template <class T>
int Array<T>::seqSearch(T key) {
for(int i = 0;i < size;i++){
if(alist[i] == key){
return i;
}
}
return -1;
}
// 插入排序
template <class T>
void Array<T>::insertSort(){
T temp;
int j;
for(int i = 1;i < size;i++){
temp = alist[i];
for(j = i;j > 0 && temp < alist[j - 1];j--){
alist[j] = alist[j - 1];
}
alist[j] = temp;
}
}
// 选择排序
template <class T>
void Array<T>::selectSort(){
int m;
T temp;
for(int i = 0;i < size - 1;i++){
m=i;
for(int j = i + 1;j < size;j++){
if(alist[j] < alist[m]){
m = j;
}
}
if(m != i){
temp = alist[i];
alist[i] = alist[m];
alist[m] = temp;
}
}
}
template <class T>
void Array<T>::bubbleSort(){
T temp;
for(int i = 0;i < size - 1;i++){
for(int j = 0;j < size - 1 - i;j++){
if(alist[j] > alist[j + 1]){
temp = alist[j];
alist[j] = alist[j + 1];
alist[j + 1] = temp;
}
}
}
}
/********** End **********/
int main()
{
int a[5] = {3, 6, 1, 8, 2};
Array<int> iArray(a, 5);
iArray.insertSort();
iArray.output();
double d[4] = {4.1, 3.2, 5.6, 1.9};
Array<double> dArray(d, 4);
dArray.selectSort();
dArray.output();
char c[3] = {'g', 'c', 'A'};
Array<char> cArray(c, 3);
cArray.bubbleSort();
cArray.output();
int b[4] = {-1, 2, 0, 5};
Array<int> bArray(b, 4);
cout<< bArray.seqSearch(0)<< endl;
cout<< bArray.seqSearch(3)<< endl;
return 0;
}