C++实践参考——数组类运算的实现

【项目-数组类运算的实现】

  设计数组类Array,为了实现测试函数中要求的功能,请补足相关的函数(构造、析构函数)和运算符重载的函数。

  实现策略提示:可以将测试函数中的语句加上注释,取消一句的注释,增加相应的函数,以渐增地实现所有的功能,避免全盘考虑带来的困难。

class Array
{
private:
    int* list;      //用于存放动态分配的数组内存首地址
    int size;       //数组大小(元素个数)
public:
    //成员函数声明
};
//要求测试函数能够运行出正确、合理的结果:
int main()
{
    int a[8]= {1,2,3,4,5,6,7,8};
    int b[8]= {10,20,30,40,50,60,70,80};
    Array array1(a,8),array3,array4;
    const Array array2(b,8);
    array4=array3=array1+array2;
    array3.show();
    array4.resize(20);
    array4[8]=99;
    cout<<array4[8]<<endl;
    cout<<array2[3]<<endl;
    return 0;
}

[参考解答]

#include <iostream>
#include <iomanip>
#include <cassert>
using namespace std;

class Array
{
private:
    int* list;      //用于存放动态分配的数组内存首地址
    int size;       //数组大小(元素个数)
public:
    Array(int sz = 50);     //构造函数
    Array(int a[], int sz);     //构造函数
    Array(const Array &a);  //拷贝构造函数
    ~Array();          //析构函数
    Array operator + (const Array &a2);     //重载"="
    Array &operator = (const Array &a2);    //重载"="
    int &operator[] (int i); //重载"[]"
    const int &operator[] (int i) const;
    int getSize() const;        //取数组的大小
    void resize(int sz);        //修改数组的大小
    void show() const;
};

Array::Array(int sz)  //构造函数
{
    assert(sz >= 0);//sz为数组大小(元素个数),应当非负
    size = sz;  // 将元素个数赋值给变量size
    list = new int [size];  //动态分配size个int类型的元素空间
}

Array::Array(int a[], int sz)
{
    assert(sz >= 0);//sz为数组大小(元素个数),应当非负
    size = sz;  // 将元素个数赋值给变量size
    list = new int [size];  //动态分配size个int类型的元素空间
    for (int i = 0; i < size; i++) //从对象X复制数组元素到本对象
        list[i] = a[i];
}

Array::~Array()   //析构函数
{
    delete [] list;
}

//拷贝构造函数
Array::Array(const Array &a)
{
    size = a.size; //从对象x取得数组大小,并赋值给当前对象的成员
    //为对象申请内存并进行出错检查
    list = new int[size];   // 动态分配n个int类型的元素空间
    for (int i = 0; i < size; i++) //从对象X复制数组元素到本对象
        list[i] = a.list[i];
}

Array Array::operator + (const Array &a2)
{
    assert(size == a2.size);    //检查下标是否越界
    //如果本对象中数组大小与a2不同,则删除数组原有内存,然后重新分配
    Array total(size);
    for (int i = 0; i < size; i++)
        total.list[i] = list[i]+a2.list[i];
    return total;   //返回当前对象的引用
}

//重载"="运算符,将对象a2赋值给本对象。实现对象之间的整体赋值
Array &Array::operator = (const Array& a2)
{
    if (&a2 != this)
    {
        //如果本对象中数组大小与a2不同,则删除数组原有内存,然后重新分配
        if (size != a2.size)
        {
            delete [] list; //删除数组原有内存
            size = a2.size; //设置本对象的数组大小
            list = new int[size];   //重新分配n个元素的内存
        }
        //从对象X复制数组元素到本对象
        for (int i = 0; i < size; i++)
            list[i] = a2.list[i];
    }
    return *this;   //返回当前对象的引用
}

//重载下标运算符,实现与普通数组一样通过下标访问元素,并且具有越界检查功能
int &Array::operator[] (int n)
{
    assert(n >= 0 && n < size); //检查下标是否越界
    return list[n];         //返回下标为n的数组元素
}
//常对象时,会调用这个函数,运算结果(引用)将不能再被赋值
const int &Array::operator[] (int n) const
{
    assert(n >= 0 && n < size); //检查下标是否越界
    return list[n];         //返回下标为n的数组元素
}

//取当前数组的大小
int Array::getSize() const
{
    return size;
}

//将数组大小修改为sz
void Array::resize(int sz)
{
    assert(sz >= 0);    //检查sz是否非负
    if (sz == size) //如果指定的大小与原有大小一样,什么也不做
        return;
    int* newList = new int [sz];    //申请新的数组内存
    int n = (sz < size) ? sz : size;//将sz与size中较小的一个赋值给n
    //将原有数组中前n个元素复制到新数组中
    for (int i = 0; i < n; i++)
        newList[i] = list[i];
    delete[] list;      //删除原数组
    list = newList; // 使list指向新数组
    size = sz;  //更新size
}

void Array::show() const
{
    for (int i = 0; i < size; i++)
        cout<< list[i]<<" ";
    cout<<endl;
}

int main()
{
    int a[8]= {1,2,3,4,5,6,7,8};
    int b[8]= {10,20,30,40,50,60,70,80};
    Array array1(a,8),array3,array4;
    const Array array2(b,8);
    array4=array3=array1+array2;
    array3.show();
    array4.resize(20);
    array4[8]=99;
    cout<<array4[8]<<endl;
    cout<<array2[3]<<endl;
    return 0;
}
时间: 2024-11-05 13:32:01

C++实践参考——数组类运算的实现的相关文章

C++实践参考——Time类中的运算符重载

[项目-Time类中的运算符重载] 实现Time类中的运算符重载. class CTime { private: unsigned short int hour; // 时 unsigned short int minute; // 分 unsigned short int second; // 秒 public: CTime(int h=0,int m=0,int s=0); void setTime(int h,int m,int s); void display(); //二目的比较运算符

第九周上机实践项目 项目2-我的数组类

问题及代码: [项目-我的数组类] 阅读程序,请完成成员函数的定义,因为存在指针型的数据成员,注意需要深复制的构造函数. #include<iostream> using namespace std; class MyArray { private: int *arrayAddr; //保存一个有len个整型元素的数组的首地址 int len; //记录动态数组的长度 int max; //动态数组中的最大值(并非动态数组中必须要的数据成员) public: MyArray(int *a, i

Eigen 3.3.7 数组类(Array)和元素操作

数组类(Array)和元素操作 原文地址:http://eigen.tuxfamily.org/dox/group__TutorialArrayClass.html Array 类有什么用? Array 类提供了一个一般用途的数组,用于操作元素相关算法,就像 Matrix 专门用于实现线性代数算法.更具体一点,Array 提供了对元素进行操作的方法,这些操作大部分与线性代数算法无关.比如数组中每个元素都加一个常量或者两个同维数组对应元素相乘. Array 类型 Array 是一个模板类,和Mat

实验11:Problem D: 分数类的模板数组类

在默认构造函数里面,分母的默认值不能为0!! Home Web Board ProblemSet Standing Status Statistics Problem D: 分数类的模板数组类 Problem D: 分数类的模板数组类 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 509  Solved: 350[Submit][Status][Web Board] Description 封装一个模板数组类Array,支持一下操作: 1. 构造函

爪哇国新游记之十五----泛型动态数组类

import java.lang.reflect.Array; /** * 泛型动态数组类 * */ public class DynamicArray<T extends Object>{ private T[] arr; private Class<T> type; private int currCount; private static final int InitSize=2; public DynamicArray(Class<T> type){ this.

java中的数组类与集合类详解及原理介绍

一.类结构概述 当需要存储大量数据对象时,需要用到数组类或者集合类.java中的类结构如下(红色为接口,蓝色为类): Iterator接口:是对collection进行迭代的迭代器,它允许调用者利用定义良好的语义在迭代期间从迭代器所指向的collection移除元素. Collection接口:Collection表示一组对象,最小存储数据颗粒是单一的 List接口:是数组形式,允许数据重复:是有序的 collection(也称为序列),此接口的用户可以对列表中每个元素的插入位置进行精确地控制,

Problem S: 分数类的模板数组类

Problem S: 分数类的模板数组类 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 2155  Solved: 1624[Submit][Status][Web Board] Description 封装一个模板数组类Array,支持一下操作: 1. 构造函数Array(int n),将数组初始化为n个存储空间: 2. 函数input(int n),读取最多n个元素,但不能超过数组存储空间的上限: 3. 重载下标运算符,返回数组的元素. 封装一

C++——模板、数组类

1.函数模板:可以用来创建一个通用功能的函数,以支持多种不同形参,进一步简化重载函数的函数体设计. 声明方法:template<typename 标识符> 函数声明 求绝对值的模板 #include<iostream>               --编译器从调用abs函数时实参的类型,推导出函数模板的类型参数.using namespace std;             --如该题从调用abs(int)推导出模板中类型参数T为int型. template<typenam

设计数组类扩展数组的功能

建立专门的数组类处理有关数组的操作 数组是几乎所支持的组织数据的方法.C和C++对数组类型提供了内置支持,使我们利用数组实现软件中需要的各种实用的功能.但是,这种支持仅限于用来读写单个元素的机制.C++不支持数组的抽象abstraction,也不支持对整个数组的操作.例如:把一个数组赋值给另外一个数组,对两个数组进行相等比较或者想知道数组的大小size,等等.对C++而言,数组是从C语言中继承来的,它反映了数据与对其进行操作的算法的分离,有浓厚的过程化程序设计的特征.数组并不是C++语言的一等公