题目
4 .设定义一个类:
class ListArray
{
private :
int size;
int elem;
int *p;
public :
ListArray (int s=100 );
void put(int n);
void print();
~ListArray();
};
请完成该类成员函数的定义和测试程序的设计。
【提示】编写void put(int n)函数时,注意考虑数组满的情况。
如果数组已满,则没有空间存储n,此时需动态申请新的内存空间,
其大小应比原数组大小大1 ,并将原数组元素备份到新数组,
新数组的最后一个元素存放n,当然不要忘记释放为原数组动态分配的内存空间。
代码
#include <iostream>
using namespace std ;
class ListArray
{
public :
ListArray(int s = 100 );
void put(int n);
void print();
~ListArray();
private :
int size;
int elem;
int *p;
};
ListArray::ListArray(int s)
{
size = s;
elem = 0 ;
p = new int [size];
}
void ListArray::put(int n)
{
if (elem < size)
{
p[elem] = n;
elem++;
}
else
{
int *temp = new int [size + 1 ];
for (int i = 0 ; i < size; i++)
{
temp[i] = p[i];
}
delete [] p;
p = temp;
p[elem] = n;
elem++;
size++;
}
}
void ListArray::print()
{
for (int i = 0 ; i < elem; i++)
{
if ( !(i % 10 ))
cout << endl;
cout << p[i] << " " ;
}
}
ListArray::~ListArray()
{
if (p != NULL)
{
delete [] p;
p = NULL;
}
size = 0 ;
elem = 0 ;
}
int main()
{
ListArray a(10 );
for (int i = 0 ; i < 11 ; i++)
{
a.put(i);
}
a.print();
return 0 ;
}