day 0912

cpp 复制代码
#include <iostream>
#include <cstring>

using namespace std;
class myString
{
private:
    char *str;  //记录c风格的字符串
    int size;   //记录字符串的实际长度
public:
    //无参构造
    myString():size(10)
    {
        str = new char[size];   //构造一个长度为10的字符串
        strcpy(str," ");         //赋值为空串
    }
    //有参构造
    myString(const char *s)
    {
        size = strlen(s);
        str =new char[size+1];
        strcpy(str,s);
    }
    //拷贝构造
    myString(const myString &other)
    {
        size = strlen(other.str);
        str =new char[size+1];
        strcpy(str,other.str);
    }
    //析构函数
    ~myString ()
    {
        delete str;
        str = nullptr;
    }
    //拷贝赋值函数
    myString & operator=(const myString &other)
    {
        if(this != &other)
        {
            if(this->str != NULL)
            {
                delete str;
            }
            this->str = new char[strlen(other.str)+1];
            strcpy(str,other.str);
        }
        return *this;
    }
    //判空函数
    bool str_empty()
    {
        return str == nullptr;
    }
    //size函数
    int str_size()
    {
        return size;
    }
    //c_str函数
       char *c_str()
       {
           char *c_string = new char[size +1];
           strcpy(c_string, str);
           return c_string;
       }
    //at函数
    char &at(int pos)
    {
        if(pos<0||pos>size-1)
            return*str;
            return *(str+pos);
    }
    //加号运算符重载
    const myString operator+(const myString &s)
    {
        myString  tmp;
        tmp.size = size + s.size;
        tmp.str = new char[tmp.size+1];
        strcpy(tmp.str,str);
        char *dstr = tmp.str + size;
        strcpy(dstr, s.str);
        dstr = nullptr;
        return tmp;
    }
    //加等于运算符重载
    const myString operator+=(const myString &s)
    {
        myString tmp(*this);
        size = tmp.size + s.size;
        delete str;
        str = new char[size+1];
        strcpy(str,tmp.str);
        char *dstr = str + tmp.size;
        strcpy(dstr, s.str);
        dstr = nullptr;
        return *this;
    }
    //关系运算符重载(>)
    bool operator >(const myString &s)
    {
        int i=0;
        for(;(*(str+i)==*(s.str+i) && *(str+i)!=0 && *(s.str+i)!=0);i++);
        return *(str+i)-*(s.str+i)>0;
    }
    //中括号运算符重载
    char &operator[](int pos)
    {
        if(pos<0||pos>size-1)
            return *str;
        return *(str+pos);
    }
    //定义成员函数
    void show()
    {
        cout<<str<<endl;
    }
};

int main()
{
   myString s1("hello ");
   myString s2("world");
   myString s3;
   s3 = s1+s2;
   s3.show();

   myString s4;
   s4 = s3;
   s4.show();

   s1+=s2;
   s1.show();

   s1[0]='H';
   s1.show();

   s1.at(6)='W';
   s1.show();
   return 0;
}
相关推荐
故事和你911 小时前
洛谷-数据结构1-1-线性表1
开发语言·数据结构·c++·算法·leetcode·动态规划·图论
脱氧核糖核酸__1 小时前
LeetCode热题100——53.最大子数组和(题解+答案+要点)
数据结构·c++·算法·leetcode
脱氧核糖核酸__2 小时前
LeetCode 热题100——42.接雨水(题目+题解+答案)
数据结构·c++·算法·leetcode
王老师青少年编程3 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:数列分段 Section I
c++·算法·编程·贪心·csp·信奥赛·线性扫描贪心
王老师青少年编程3 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:分糖果
c++·算法·贪心算法·csp·信奥赛·线性扫描贪心·分糖果
leaves falling3 小时前
C++模板进阶
开发语言·c++
无敌昊哥战神4 小时前
【保姆级题解】力扣17. 电话号码的字母组合 (回溯算法经典入门) | Python/C/C++多语言详解
c语言·c++·python·算法·leetcode
脱氧核糖核酸__4 小时前
LeetCode热题100——238.除了自身以外数组的乘积(题目+题解+答案)
数据结构·c++·算法·leetcode
ouliten4 小时前
C++笔记:std::invoke
c++·笔记
j_xxx404_5 小时前
C++算法:哈希表(简介|两数之和|判断是否互为字符重排)
数据结构·c++·算法·leetcode·蓝桥杯·力扣·散列表