【C++面向对象——群体类和群体数据的组织】实现含排序功能的数组类(头歌实践教学平台习题)【合集】

news2025/1/7 21:46:02

目录😋

任务描述

相关知识

1. 相关排序和查找算法的原理

2. C++ 类与成员函数的定义

3. 数组作为类的成员变量的处理

4. 函数参数传递与返回值处理

编程要求

测试说明

通关代码

测试结果


任务描述

本关任务:

将直接插入排序、直接选择排序、冒泡排序、顺序查找函数封装到数组类 Array 中,作为成员函数。

相关知识

为了完成本关任务,你需要掌握:

  1. 相关排序和查找算法的原理
  2. C++ 类与成员函数的定义
  3. 数组作为类的成员变量的处理
  4. 函数参数传递与返回值处理

1. 相关排序和查找算法的原理

  • 直接插入排序
    • 原理:把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所有的记录插入完为止,就像人们按大小顺序整理手中的扑克牌一样。具体过程是从第二个元素开始,依次将每个元素与前面已排好序的元素从后往前进行比较,找到合适的位置插入该元素,使得插入后前面的序列依然有序。
    • 示例代码(非成员函数形式,便于理解原理):
    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;  // 表示未找到目标元素
    }
    

2. C++ 类与成员函数的定义

  • 类的基本结构
    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;
      }
      

3. 数组作为类的成员变量的处理

  • 内存管理方面
    • 当把数组作为类的成员变量时(如上面示例中的 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. 函数参数传递与返回值处理

  • 参数传递
    • 对于排序成员函数,一般不需要额外的参数传入(因为操作的对象就是类中存储的数组成员变量),但像顺序查找成员函数,就需要传入要查找的目标元素作为参数,要理解值传递、指针传递、引用传递等不同参数传递方式的特点及适用场景,选择合适的方式来传递参数,保证函数功能的正确实现且避免不必要的内存开销等问题。
  • 返回值处理
    • 排序成员函数通常不需要返回值(因为它们直接对类中的数组进行原地排序操作),而顺序查找成员函数需要返回查找目标元素在数组中的索引,如果没找到则返回合适的值(如 -1)来表示查找失败,要正确处理这些返回值情况,以便在调用函数的地方根据返回值进行相应的后续操作。
 

综上所述,掌握以上这些知识要点,就可以顺利地将相关排序和查找函数封装到 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;
}

测试结果

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2272860.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[开源]自动化定位建图系统

系统状态机&#xff1a; 效果展示&#xff1a; 1、 机器人建图定位系统-基础重定位&#xff0c;定位功能演示 2、 机器人建图定位系统-增量地图构建&#xff0c;手动回环检测演示 3、敬请期待… 开源链接&#xff1a; 1、多传感器融合里程计 https://gitee.com/li-wenhao-lw…

简单的jmeter数据请求学习

简单的jmeter数据请求学习 1.需求 我们的流程服务由原来的workflow-server调用wfms进行了优化&#xff0c;将wfms服务操作并入了workflow-server中&#xff0c;去除了原来的webservice服务调用形式&#xff0c;增加了并发处理&#xff0c;现在想测试模拟一下&#xff0c;在一…

conda/pip基本常用命令理解与整理

最近配置了两轮pytorch环境&#xff0c;由于要频繁用到各种conda和pip命令&#xff0c;所以再此整理一下。 文章目录 前言&#xff1a;conda虚拟环境总结与解读Conda和pip的理解区别和联系命令格式 conda环境命令查看创建和删除导出与导入激活和退出 包管理命令安装和删除文件批…

Maven 详细配置:Maven settings 配置文件的详细说明

Maven settings 配置文件是 Maven 环境的重要组成部分&#xff0c;它用于定义用户特定的配置信息和全局设置&#xff0c;例如本地仓库路径、远程仓库镜像、代理服务器以及认证信息等。settings 文件分为全局配置文件&#xff08;settings.xml&#xff09;和用户配置文件&#x…

Unity-Mirror网络框架-从入门到精通之Chat示例

文章目录 前言Chat聊天室Authentication授权ChatAuthenticatorChat示例中的授权流程聊天Chat最后 前言 在现代游戏开发中&#xff0c;网络功能日益成为提升游戏体验的关键组成部分。Mirror是一个用于Unity的开源网络框架&#xff0c;专为多人游戏开发设计。它使得开发者能够轻…

复杂园区网基本分支的构建

目录 1、各主机进行网络配置。2、交换机配置。3、配置路由交换&#xff0c;进行测试。4、配置路由器接口和静态路由&#xff0c;进行测试。5、最后测试任意两台主机通信情况 模拟环境链接 拓扑结构 说明&#xff1a; VLAN标签在上面的一定是GigabitEthernet接口的&#xff0c…

这是什么操作?强制迁移?GitLab 停止中国区用户访问

大家好&#xff0c;我是鸭鸭&#xff01; 全球知名代码托管平台 GitLab 发布通告&#xff0c;宣布不再为位于中国大陆、香港及澳门地区的用户提供访问服务&#xff0c;并且“贴心”建议&#xff0c;可以访问极狐 GitLab。 极狐 GitLab 是一家中外合资公司&#xff0c;宣称获得…

CDP集成Hudi实战-spark shell

[〇]关于本文 本文主要解释spark shell操作Hudi表的案例 软件版本Hudi1.0.0Hadoop Version3.1.1.7.3.1.0-197Hive Version3.1.3000.7.3.1.0-197Spark Version3.4.1.7.3.1.0-197CDP7.3.1 [一]使用Spark-shell 1-配置hudi Jar包 [rootcdp73-1 ~]# for i in $(seq 1 6); do s…

设计模式学习[15]---适配器模式

文章目录 前言1.引例2.适配器模式2.1 对象适配器2.2 类适配器 总结 前言 这个模式其实在日常生活中有点常见&#xff0c;比如我们的手机取消了 3.5 m m 3.5mm 3.5mm的接口&#xff0c;只留下了一个 T y p e − C Type-C Type−C的接口&#xff0c;但是我现在有一个 3.5 m m 3.…

数据挖掘——数据预处理

数据挖掘——数据预处理 数据预处理数据预处理 ——主要任务数据清洗如何处理丢失的数据如何处理噪声数据如何处理不一致数据 数据集成相关分析相关系数(也成为皮尔逊相关系数)协方差 数据规约降维法&#xff1a;PCA主成分分析降数据——抽样法数据压缩 数据预处理 数据预处理…

Unity-Mirror网络框架-从入门到精通之CCU示例

文章目录 前言什么是CCU&#xff1f;测试结果最后 前言 在现代游戏开发中&#xff0c;网络功能日益成为提升游戏体验的关键组成部分。Mirror是一个用于Unity的开源网络框架&#xff0c;专为多人游戏开发设计。它使得开发者能够轻松实现网络连接、数据同步和游戏状态管理。本文…

如何在 Ubuntu 22.04 上安装 Nagios 服务器教程

简介 在本教程中&#xff0c;我们将解释如何在 Ubuntu 22.04 上安装和配置 Nagios&#xff0c;使用 Apache 作为 Web 服务器&#xff0c;并通过 Let’s Encrypt Certbot 使用 SSL 证书进行保护。 Nagios 是一个强大的监控系统&#xff0c;它可以帮助组织在 IT 基础设施问题影…

大语言模型训练所需的最低显存,联邦大语言模型训练的传输优化技术

联邦大语言模型训练的传输优化技术 目录 联邦大语言模型训练的传输优化技术大语言模型训练所需的最低显存大语言模型训练所需的最低显存 基于模型微调、压缩和分布式并行处理的方法,介绍了相关开源模型及技术应用 核心创新点 多维度优化策略:综合运用基于模型微调、模型压缩和…

Javascript算法——贪心算法(一)

贪心算法详解&#xff08;JavaScript&#xff09;&#xff08;局部最优->全局最优&#xff09; 贪心算法&#xff08;Greedy Algorithm&#xff09;是一种在每一步选择中都采取当前状态下的最优选择&#xff08;局部最优&#xff09;的算法设计方法。通过局部最优解的累积&…

141.《mac m系列芯片安装mongodb详细教程》

文章目录 下载从官网下载安装包 下载后双击解压出文件夹安装文件名修改为 mongodb配置data存放位置和日志log的存放位置启动方式一方式二方式二:输入mongo报错以及解决办法 本人电脑 m2 pro,属于 arm 架构 下载 官网地址: mongodb官网 怎么查看自己电脑应该下载哪个版本,输入…

【ArcGISPro/GeoScenePro】裁剪和打包栅格数据

检查并处理扫描地图 数据 https://arcgis.com/sharing/rest/content/items/535efce0e3a04c8790ed7cc7ea96d02d/data 使用标准相机或扫描仪创建的数字影像通常存储在 RGB 颜色模型中,这意味着这些影像将由红色、绿色和蓝色三个栅格组成。 此扫描地图在提供给您之前已在坐标系…

【C++】B2109 统计数字字符个数

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 &#x1f4af;前言&#x1f4af;题目描述与输入输出要求题目&#xff1a;统计数字字符个数样例输入输出 &#x1f4af;方法分析与代码实现方法 1&#xff1a;使用 fgets 读取输入并手动判断数字字符代码实…

基于32单片机的智能语音家居

一、主要功能介绍 以STM32F103C8T6单片机为控制核心&#xff0c;设计一款智能远程家电控制系统&#xff0c;该系统能实现如下功能&#xff1a; 1、可通过语音命令控制照明灯、空调、加热器、窗户及窗帘的开关&#xff1b; 2、可通过手机显示和控制照明灯、空调、窗户及窗帘的开…

git理解记录

文章目录 1. 背景2. 基本概念3. 日常工作流程4. 其他常见操作4.1 merge合并操作4.2 tag打标签操作4.3 remoute远程操作4.4 撤销修改 git理解记录 1. 背景 git作为分布式版本控制系统&#xff0c;开源且免费&#xff0c;相比svn集中式版本控制系统存在速度快(HEAD指针指向某次co…

开启宝塔Nginx防火墙支付返回失败解决方法

1.把/plugin.php加到Nginx防火墙URL白名单 包括支付服务器回调ip 2.如果支持带参数 /plugin.php?idzhifufm:notify 加到Nginx防火墙标准模式-URL白名单带参数 如果上面都不行 就把下面的IP加入白名单 39.107.193.172 47.94.194.103 47.104.216.190