第十四周实验报告(一)

来源:互联网 发布:excel去除相同数据 编辑:程序博客网 时间:2024/06/05 14:31

/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 作 者: 李冠绩
* 完成日期: 2012 年5月28日
* 版 本 号: V1.0
* 对任务及求解方法的描述部分
* 输入描述:
* 问题描述:
* 程序输出:
* 程序头部的注释结束

#include<iostream>
using namespace std;
class MyArray
{
private:
 int *arr;  //用于存放动态分配的数组内存首地址
 int size;  //数组大小
public:
 MyArray(int sz=50);
 MyArray(int a[],int sz); //由一个内置类型的数组初始化
 MyArray(const MyArray &A); //拷贝构造函数
 ~MyArray(void);    //析构函数,注意释放空间
 MyArray&operator=const MyArray &A); //重载“=”使得数组对象可以整体赋值
 int& operator[](int i);  //重载[],使得Array对象也可以如C++普通数组一样,用a[i]形式取出值【选做】
 bool operator == (MyArray& A); //重载==,使得Array对象能整体判断两个数组是否相等(size相等且对应元素相等)
 MyArray operator + (MyArray& A); //重载+,使两个Array对象可以整体相加(前提大小相等)【选做】
 friend ostream& operator << (ostream& out,MyArray& A); //重载<<,输出数组
 int GetSize(void)const; //取数组大小;
 void Resize(int sz); //修改数组的大小,如果sz大于数组的原大小,增加的元素初始为;sz小于数组的原大小,舍弃后面的元素【选做】
};

MyArray::MyArray(int sz)
{
 arr=new int[sz];
 size=sz;
 for(int i=0;i<sz;i++)
  arr[i]=0;

}

MyArray::MyArray(int a[],int sz) //由一个内置类型的数组初始化
{  
 arr=new int[sz]; 
 for(int i=0;i<sz;++i)
  *(arr+i)=*(a+i);  
 size = sz;
}

MyArray::MyArray(const MyArray &A) //拷贝构造函数
{
 arr=new int[A.size];
 for(int i=0;i<A.size;++i) 
  *(arr+i)=*(A.arr+i);  
 size=A.size;
}

MyArray::~MyArray(void) //析构函数,注意释放空间
{
 if (!arr)  
  delete [] arr;
}

MyArray & MyArray::operator =(const MyArray &A) //重载“=”使得数组对象可以整体赋值
{
 arr=new int[A.size];
 for (int i=0; i<A.size; ++i) 
  *(arr+i)=*(A.arr+i);   //将数组arr中元素逐个赋值
 size=A.size;
 return *this;
}

MyArray MyArray::operator + (MyArray& A) //重载+,使两个Array对象可以整体相加(前提大小相等)【选做】
{
 MyArray M(A);
 if(size!=A.size)
 {
  cout<<"两个Array对象不相等,不能相加!"<<endl;
 }
 for(int i=0;i<size;++i)
 {
  *(M.arr+i)=*(arr+i)+*(A.arr+i);
 }
 return M;
}

ostream& operator<<(ostream& output,MyArray& A)  //重载<<,输出数组
{
 for(int i=0;i<A.size;++i)
  output<<*(A.arr+i)<<"  ";
 cout<<endl;
 return output; 
}

int MyArray::GetSize(void)const //取数组大小;
{
 return size;
}

void MyArray::Resize(int sz) //修改数组的大小,如果sz大于数组的原大小,增加的元素初始为;sz小于数组的原大小,舍弃后面的元素【选做】
{
 int *a,i=0;
 if(sz>size)
 {
  a = new int[sz];
  for( i=0;i<size;++i)
   *(a+i)=*(arr+i);
  for(i=size;i<sz;++i)
   *(a+i)=0;
  arr = new int[sz];
  for(i=0;i<sz;++i)
   *(arr+i)=*(a+i);
  size=sz;
 }
 else
 {
  a = new int[sz];
  for(i=0;i<sz;++i)
   *(a+i)=*(arr+i);
  arr = new int[sz];
  for(i=0;i<sz;++i)
   *(arr+i)=*(a+i);
  size=sz;
 }
}

int main()
{
 int a[10]={1,2,3,4,5,6,7,8,9,10};
 int b[10]={4,5,6,7,8,9,10,11,12,13};
 MyArray arr1(a,10);
 MyArray arr2(b,10);
 MyArray arr3(10);
 cout<<arr3;
 arr3 = arr1 +arr2;
 cout<<arr3;
 arr3.Resize(20);
 cout<<arr3;
 arr3.Resize(5);
 cout<<arr3;
 system("PAUSE");
 return 0;
}

 

运行结果:

0 0 0 0 0 0 0 0 0 0
5 7 9 11 13 15 17 19 21 23
5 7 9 11 13 15 17 19 21 23 0 0 0 0 0 0 0 0 0 0
5 7 9 11 13
请按任意键继续. .

 

原创粉丝点击