/*
*Corpyright (c)2013,烟台大学计算机学院
*All right reseved.
*作者:z张梦佳
*完成日期:2014年4月14日
*版本号:v1.0
*输入描述:
*问题描述:在P324基础上,在String类中增加一个数据成员len表示字符串中字符个数,然后再构造String类的加、减运算。其中,s1 + s2将两个字符串的连接起来;s1 - s2是将s1的尾部空格和s2的前导空格去除后的连接。!
*程序输出:
*问题分析:
*算法设计:
*/
#include <iostream>
#include <Cstring>
using namespace std;
class String
{
public:
String( );
String(const char *s);
String(String &str);
~String();
void display( );
friend String operator + (String &s1,String &s2 );
friend String operator - (String &s1,String &s2 );
private:
char *p;
int len;
};
String::String()
{
len = 0;
p = NULL;
}
String::String(const char *s)
{
len = strlen(s);
p = new char[len+1];
strcpy(p,s);
}
String::String(String &str)
{
len = str.len;
if(p!=NULL) delete []p;
p = new char[len+1];
strcpy(p,str.p);
}
String::~String()
{
if(!p) delete []p;
}
void String::display( )
{
cout<<p<<endl;
}
String operator + (String &s1,String &s2 )
{
String s;
s.len=s1.len+s2.len;
s.p=new char[s.len+1];
strcpy(s.p,s1.p);
strcat(s.p,s2.p);
return s;
}
String operator - (String &s1,String &s2 )
{
String s;
s.len=s1.len+s2.len;
s.p=new char[s.len];
strcpy(s.p,s1.p);
strcat(s.p,s2.p);
for(int i=s1.len-2;i<s.len-1;i++)
{
s.p[i]=s.p[i+3];
}
return s;
}
int main( )
{
String string1(" Hello "), string2(" World ");
string1.display();
string2.display();
String string3;
string3 = string1 + string2;
string3.display();
string3 = string1 - string2;
string3.display();
return 0;
}
感悟
贺老师,这个刚开始是在是做不出来,小小的剽窃了老师的创意,不过老师的程序不能在我电脑运行。。。
后面是自己写的 ,,。。