程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 編程解疑 >> 編程-使用類模板時報了一些錯誤,求改正。。。

編程-使用類模板時報了一些錯誤,求改正。。。

編輯:編程解疑
使用類模板時報了一些錯誤,求改正。。。

#include <iostream>
using namespace std;
template <typename T>
class array
{
private:
T *A;
int L;
public:
array(int a);
array();
array(array<T> &);
void datain(T a);
friend array<T> operator+(array<T>&a,array<T>&b);
friend int big(array<T>&a,array<T>&b);
void operator=(const array<T>&);
void show();
T average();
~array();
};
template <typename T>
array<T>::array(int a)
{
int c=0;
A=new T[a];
while (c<a)
{
cin>>A[c];
c++;
}
L=a;
}
template <typename T>
array<T>::array()
{
A=NULL; L=0;
}
template <typename T>
array<T>::~array()
{
delete []A;
}
template <typename T>
array<T>::array(array<T> &p)
{
L=p.L;
A=new T[L];
for (int j=0;j<L;j++)
A[j]=p.A[j];
}
template <typename T>
void operator=(const array<T>& p)
{
L=p.L;
A=new T[L];
for (int j=0;j<L;j++)
A[j]=p.A[j];
}
template <typename T>
void array<T>::datain(T a)
{
A[L-1]=a;
}
template <typename T>
friend int big(array<T>&a,array<T> &b)
{
if (a.L>=b.L)
return a.L;
else
return b.L;
}
template <typename T>
friend array<T> operator+(array<T>&a,array<T>&b)
{
array<T> c;
int BIG=big(a,b);
c.L=BIG;
c.A=new T[BIG];
for (int i=0;i<BIG;i++)
{
c.A[i]=a.A[i]+b.A[i];
}
return c;
}
template <typename T>
T array<T>::average()
{
T all=0;
for (int i=0;i<L;i++)
{
all+=A[i];
}
return all/L;
}
template <typename T>
void array<T>::show()
{
for (int i=0;i<L;i++)
cout<<A[i]<<" ";
cout<<endl;
}
int main()
{
array<int> A1(3);
A1.show();
A1.datain(6);
A1.show();
cout<<A1.average()<<endl;
array<int> B(3);
array<int> C;
C=A1+B;
C.show();
return 0;
}圖片

最佳回答:


先說下幾個明顯點的問題吧:
1.所有的<>,<<符號都打錯了,可以按Shift+space轉換下。
2.友元函數在類外實現的時候不用加friend。
3.“=”賦值運算符重載實現的時候沒有加“array::”。
4.重載的+這個函數若是兩個長度不相等的array相加就會造成越界,假設b.L為3,a.L為2,那麼for循環裡面最後會出現c.A[3]=a.A[3]+b.A[3],顯然a.A這個數組根本沒有這個下標,它最多為a.A[2]。可以用兩個循環給要返回的數組賦值,先賦值兩個都有元素的位置,再復制另一個裡面多余的元素到相應的位置。

YXTS122
u010776685
YXTS122
u010776685
u010776685
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved