⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 p38test.cpp

📁 数据结构各种算法的实现
💻 CPP
字号:
#include <iostream.h>
#include <stdlib.h>

template < class Type > class Array {
public:
    Array ( int Size = DefaultSize );
    Array ( const Array <Type> &x );
    ~Array() { delete[] element; }
    Array <type> &operator = ( const Array<Type> &A);
    Type& operator [] ( int i );
    Array <Type> operator Type *() const { return elements; }
    int Length() const { return ArraySize; }
    void ReSize ( int sz;);
private:
    Type *elements;
    int ArraySize;
    void getArray();
}



template <class Type> void Array<Type>::getArray() {
    elements = new Type[ArraySize];
    if ( elements == 0 ) cerr << "Memory Allocation Error" << endl;
}

template <class Type> void Array<Type>::Array (int sz) {
    if ( sz <= 0 ) { cerr << "Invalid Array Size" << endl; return; }
    ArraySize = sz;
    getArray();
}

template <class Type> void Array<Type>::Array ( const Array<Type> &x ) {
    int ArraySize = n = x.ArraySize;
    elements = new Type[n];

    if ( elements == 0 ) { cerr << "Memory Allocation Error" << endl; return; }
    Type *srcptr = x.elements;
    Type *destptr = elements;
    while (n--) *destptr++ = * srcptr++ ;
}

template <class Type> Type& Array<Type>::operator[] (int i) {
    if ( i < 0 || i > ArraySize - 1 ) cerr << "Index out of Range" << endl;
    return elements[i];
}

template <class Type> void Array<Type>::Resize( int sz ) {
    if ( sz <= ArraySize ) {
	Type *newarray = new Type[sz];
	if (newarray == 0) cerr << "Memory Allocation Error" << endl;
	int n = ( sz <= ArraySize ) ? sz : ArraySize;
	Type *srcptr = elements;
	Type *destptr = newarray;
	while (n--) *destptr++ = *srcptr++ ;
	delete[] elements;
	elements = newarray;   ArraySize = sz;
    }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -