开发环境:
VS2002(VC7)
本文做如下简化:
1,假定所有维元素都是5。
2,不考虑const的[]。
3,由于只是熟悉原理,不考虑各种异常情况。
问题一,请实现一个一维整形数组,只需重载[]。
问题二,请实现一个二维整形数组,只需重载[]。
源码如下:
class CIntArray1 { public: int& operator[](int index) { return m_pData[index]; } protected: int m_pData[5]; }; class CIntArray2 { public: int* operator[](int index) { return m_pData[index]; } protected: int m_pData[5][5] ; };
测试程序:
CIntArray1 arr1; arr1[1] = -1; int i1 = arr1[1]; CIntArray2 arr2; arr2[1][1] = -2; int i2 = arr2[1][1];
三,请实现一个N(2<=n<=10)维整形数组,只需重载[]
template<int iWeiShu> class CIntArray { public: CIntArray<iWeiShu-1>& operator[](int index) { return m_pData[index]; } protected: CIntArray<iWeiShu-1> m_pData[5]; }; template<> class CIntArray<1> { public: int& operator[](int index) { return m_pData[index]; } protected: int m_pData[5]; }; 测试程序 CIntArray<1> a1; a1[1] = 4; int x1 = a1[1]; CIntArray<2> a2; a2[1][1] = 5; int x2 = a2[1][1]; CIntArray<3> a3; a3[0][0][0] =9; int x3 = a3[0][0][0];