第14周实验报告任务1

/* (程序头部注释开始)  
* 程序的版权和版本声明部分 
 
* Copyright (c) 2011, 烟台大学计算机学院学生  
 
* All rights reserved.* 文件名称:建立专门的数组类处理有关数据的操作 
* 作 者: 郭岩岩 

* 完成日期:2012 年5月 22日 

* 版 本 号: vc.1 

* 对任务及求解方法的描述部分 

* 输入描述:  

* 问题描述:  

* 程序输出:  

*程序头部的注释结束 

*/  





#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); //重载“=”使得数组对象可以整体赋值
	bool operator == (MyArray& A);	//重载==,使得Array对象能整体判断两个数组是否相等(size相等且对应元素相等)
	friend ostream& operator << (ostream& out,MyArray& A);	//重载<<,输出数组
	int GetSize(void)const;	//取数组大小;
};
MyArray::MyArray(int sz)
{
	if(sz<=0)
	{
		cout<<"error!";
		exit(1);
	}
	else
		size=sz;
	arr=new int[size];
	for(int i=0;i<=size;i++)
		*(arr+i)=0;
}

MyArray::MyArray(int a[], int sz) 
{
	if(sz<=0)
	{
		cout<<"error!";
		exit(1);
	}
	else
		size=sz;
	arr=new int[size];
	for(int i=0;i<=size;i++)
		*(arr+i)=*(a+i);
}

MyArray::MyArray(const MyArray &A) 
{
	int n=A.size ;
	size=n;
	arr=new int[n];
	int *srcptr=A.arr;//X.arr是对象A的数组首地址   
    int *destptr=arr;//arr是本对象中的数组首地址   
    while(n--)  
    {  
        *destptr=*srcptr;  
        destptr++;  
        srcptr++;  
    } 
}
MyArray::~MyArray() 
{
	delete []arr;
}

MyArray& MyArray::operator =(const MyArray &A)
{
	int n=A.size;
	if(size!=n)
	{
		delete []arr;
		arr=new int[n];
		size=n;
	}
    int *srcptr=A.arr;  
    int *destptr=arr;   
    while(n--)  
    {  
        *destptr=*srcptr;  
        destptr++;  
        srcptr++;  
    }
	return *this;
}
bool MyArray::operator ==(MyArray &A)
{
    bool eq=true;  
    int n=A.size;   //取A数组的大小   
    if (size!=n)   //大小是否一致       {  
        eq=false;  
	else
	{
        int* destptr=arr;  
        int* srcptr=A.arr;  
        while(n--)  
        {  
            if(*destptr!=*srcptr)  
            {  
                eq=false;  
                break;  
            }  
            destptr++;  
            srcptr++;  
        } 
	}
    return eq;//返回当前对象的引用   
} 

ostream& operator << (ostream& out, MyArray& A)  
{  
    for (int i = 0; i < A.size; i++)  
    {  
		out<<*(A.arr+i)<<'\t';  
    }  
    out<<endl;  
    return out;  
}

int MyArray::GetSize (void)const
{
	return size;
}
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<<arr1;
	//arr3 = arr1 +arr2;
	cout<<arr2;
	//arr3.Resize(20);
	//cout<<arr3;
	//arr3.Resize(5);
	cout<<arr3;
	system("pause");
	return 0;
} 


1       2       3       4       5       6       7       8       9       10

4       5       6       7       8       9       10      11      12      13

0       0       0       0       0       0       0       0       0       0

请按任意键继续. . .

上机感言:好晕好晕。。。。。。。。。。。

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值