2024.9.24 作业1和思维导图

#include <iostream>
#include <cstring>
using namespace std;
class My_string
{
private:
    char * ptr;      //指向字符数组的指针
    int size=15;       //字符串的最大容量
    int len;        //字符串当前容量

public:
    //无参构造
    My_string(){}

    //有参构造
    My_string(const char * src):ptr((char *)src)
    {
        cout<<"有参构造"<<endl;
        int i=0,count = 0;
        while(src[i])
        {
            count++;
            i++;
        }
        this->len = count;
        Double_dilatation();
    }

    My_string(int num,char value):len(num)  //类似string(5,'A');
    {
        cout<<"有参构造"<<endl;
        ptr = new char (this->size);
        if(this->len>this->size)
        {
            Double_dilatation();
        }
        for(int i =0;i<num;i++)
        {
            ptr[i] = value;
        }
    }
    //拷贝构造
    My_string(const My_string & other):ptr(new char(* other.ptr)),size(other.size),len(other.len)
    {
        cout <<"拷贝构造"<< endl;
    }


    //拷贝赋值
    My_string & operator=(const My_string & other)
    {
        cout <<"拷贝赋值"<< endl;
        if(this != & other)
        {
            *this->ptr = *other.ptr;
            this->size = other.size;
            this->len = other.len;
        }
        return *this;
    }
    //析构函数
    ~My_string()
    {
        cout <<"析构函数"<< endl;
        delete ptr;
    }

    //判空
    bool empty()
    {
        cout <<"判空"<< endl;
        while(ptr[0]=='\0')
        {
            return 1;
        }
        return 0;
    }
    //尾插
    void push_back(char value)
    {
        ptr[len]= value;
        len++;
    }
    //at函数实现
    char & at(int index)
    {
        return ptr[index-1];
    }
    //清空函数
    void clear()
    {
        *ptr = '\0';
        len=0;
    }
    //返回C风格字符串
    char * data()
    {
        return ptr;
    }
    //返回实际长度
    int get_length()
    {
        return this->len;
    }
    //返回当前最大容量
    int get_size()
    {
        return this->size;
    }

    //二倍扩容
    void Double_dilatation()
    {

        while(this->len>=this->size)
        {
            this->size *= 2;
        }
        char *p1 = new char (this->size);

        *p1 = *(this->ptr);

        p1 = this->ptr;


    }
    //+
    const My_string operator+(const My_string &R)const
    {
        My_string temp;
        temp.ptr = strcat(this->ptr,R.ptr);
        return ptr;
    }
    //[]
    char operator[](int i)
    {
        return ptr[i];
    }
    //>
    bool operator>(const My_string &R)const
    {
        if(strcmp(ptr,R.ptr)>0)
        {
            return 1;
        }
        return 0;
    }
    //<
    bool operator<(const My_string &R)const
    {
        if(strcmp(ptr,R.ptr)<0)
        {
            return 1;
        }
        return 0;
    }
    //==
    bool operator==(const My_string &R)const
    {
        if(strcmp(ptr,R.ptr)==0)
        {
            return 1;
        }
        return 0;
    }
    //>=
    bool operator>=(const My_string &R)const
    {
        if(strcmp(ptr,R.ptr)>=0)
        {
            return 1;
        }
        return 0;
    }
    //<=
    bool operator<=(const My_string &R)const
    {
        if(strcmp(ptr,R.ptr)<=0)
        {
            return 1;
        }
        return 0;
    }
    //!=
    bool operator!=(const My_string &R)const
    {
        if(strcmp(ptr,R.ptr)!=0)
        {
            return 1;
        }
        return 0;
    }
    //+=
    My_string & operator+=(const char * ptr)
    {
        strcat(this->ptr,ptr);
        return *this;
    }


    friend ostream &operator<<(ostream &L,const My_string &R);
    friend istream &operator<<(istream &L,My_string &R);
};


ostream &operator<<(ostream &L,const My_string &R)
{
    L<<R.ptr;
    return L;
}
istream &operator<<(istream &L,My_string &R)
{
    L>>R.ptr;
    return L;
}


int main()
{
    My_string c0;
    cout << c0 << endl;
    My_string c1("world");
    cout << c1 << endl;
    My_string c2(5,'A');
    cout << c2 << endl;
    My_string c3("world");
    cout << c3 << endl;
    cout<<(c3>c2)<<endl;
    cout<<"**************"<<endl;
//    string d2(5,'A');
//    cout << d2 << endl;
//    string d3("world");
//    cout << d3 << endl;
//    cout<<(d3>d2)<<endl;
    return 0;
}

JavaScript思维导图是一种可视化工具,用于展示和组织JavaScript编程语言的不同概念、特性和功能。它通过使用节点和连线的方式将这些信息有机地连接起来,使得开发者更容易理解和记忆。 在一个JavaScript思维导图中,通常会包含一些核心概念,例如变量、函数、条件语句、循环、对象等。这些核心概念作为主要的节点,通过连线的方式表示它们之间的关系。 除了核心概念外,思维导图还可以包含其他相关的概念和主题。例如,它可以展示JavaScript中的各种数据类型,如字符串、数字、数组、对象等。它还可以展示JavaScript中的常用方法和API,如字符串操作、数组操作、DOM操作等。 思维导图还可以通过不同的颜色、图标和字体等方式来表示特定的概念或者标记重要的内容。这有助于提醒开发者注意某些关键点或者了解到某些特殊的情况。 与传统的纸质笔记相比,JavaScript思维导图具有更好的可视化效果和交互性。开发者可以通过展开和折叠节点来调整导图的层次结构,以便更好地组织和管理不同的概念。他们还可以轻松地导出或分享导图,以便与其他人合作或者复习。 总之,JavaScript思维导图是一种强大的工具,可以帮助开发者更好地理解和掌握JavaScript编程语言。它提供了一种清晰和直观的方式来展示和组织复杂的信息,使学习和开发过程更加高效和愉快。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值