2024.9.2 作业

完成mystring类部分功能实现

代码:

/*******************************************/

文件名:work4.h

/*******************************************/

#ifndef WORK4_H
#define WORK4_H
#include <iostream>
#include<cstring>
using namespace std;
class Mystring
{
private:
    char *buf;
public:
    static int count;
public:
    Mystring()
    {
        buf = new char[1];
        *buf = '\0';
        count++;
    }
    Mystring(const char *b);
    ~Mystring()
    {
        delete[] buf;
        count--;
    }
    void show()
    {
        cout<<buf<<endl;
    }
    const Mystring &operator=(const Mystring &R);
    char at(int index);
    const Mystring operator[](int index);
    char data();
    const Mystring c_str();
    bool empty();
    int size()const;
    int length()const;
    int capacity()const;
    bool clear();
    bool push_back(char s);
    bool pop_balck();
    bool append(char s);
    Mystring &operator+=(const Mystring &R);
    const Mystring operator+(const Mystring &R);
    bool operator==(const Mystring &R);
    bool operator!=(const Mystring &R);
    bool operator>(const Mystring &R);
    bool operator>=(const Mystring &R);
    bool operator<=(const Mystring &R);
    friend ostream & operator<<(ostream &L, const Mystring &R);
    friend istream & operator>>(istream &L, Mystring &R);
};

#endif // WORK4_H

/*******************************************/

文件名:work4.cpp

/*******************************************/

#include"work4.h"
int Mystring::count = 0;
Mystring::Mystring(const char *b)
{
    int len=strlen(b);
    this->buf = new char[len + 1];
    strcpy(this->buf, b);
    count++;
}
const Mystring &Mystring::operator=(const Mystring &R)
{
    delete[] buf;
    buf = new char[std::strlen(R.buf) + 1];
    std::strcpy(buf, R.buf);
    return *this;
}
char Mystring::at(int index)
{
    if (index < 0 || index >= (int)strlen(buf)) {
        throw std::out_of_range("Index out of range");
    }
    return this->buf[index];
}
const Mystring Mystring::operator[](int index)
{
    return Mystring(&buf[index]);
}
char Mystring::data()
{
    return *this->buf;
}
const Mystring Mystring::c_str()
{
    return *this;
}
bool Mystring::empty()
{
    return "this->buf=='\0'";
}
int Mystring::size()const
{
    return strlen(this->buf);
}
int Mystring::length()const
{
    return size();
}
int Mystring::capacity()const
{
    return strlen(this->buf)+1;
}
bool Mystring::clear()
{
    delete[]this->buf;
    this->buf=new char[1];
    *buf='\0';
    return 1;
}
bool Mystring::push_back(char s)
{
    char *newBuf = new char[capacity() + 1];
    std::strcpy(newBuf, this->buf);
    newBuf[size()] = s;
    newBuf[size() + 1] = '\0';
    delete[] this->buf;
    buf = newBuf;
    return 1;
}
bool Mystring::pop_balck()
{
    if (empty())
    {
        return 0;
    }
    char *newBuf = new char[size() + 1];
    std::strncpy(newBuf, this->buf, size() - 1);
    newBuf[size() - 1] = '\0';
    delete[] this->buf;
    buf = newBuf;
    return 1;
}
bool Mystring::append(char s)
{
    return push_back(s);
}
Mystring &Mystring::operator+=(const Mystring &R)
{
    *this = *this + R;
    return *this;
}
const Mystring Mystring::operator+(const Mystring &R)
{
    Mystring temp;
    temp.buf = new char[size() + R.size() + 1];
    strcpy(temp.buf, buf);
    strcat(temp.buf, R.buf);
    return temp;
}
bool Mystring::operator==(const Mystring &R)
{
    return strcmp(buf, R.buf) == 0;
}
bool Mystring::operator!=(const Mystring &R)
{
    return !(*this == R);
}
bool Mystring::operator>(const Mystring &R)
{
    return strcmp(this->buf, R.buf) > 0;
}
bool Mystring::operator>=(const Mystring &R)
{
    return *this > R || *this == R;
}
bool Mystring::operator<=(const Mystring &R)
{
    return !(*this > R);
}
ostream & operator<<(ostream &L, const Mystring &R)
{
    L << R.buf;
    return L;
}
istream & operator>>(istream &L, Mystring &R)
{
    L>>R.buf;
    return L;
}

/*******************************************/

文件名:main.cpp

/*******************************************/

#include"work4.h"

int main()
{
    Mystring s1="hello";
    s1.show();
    Mystring s2="world!";
    s2.show();
    Mystring s3=s1+s2;
    s3.show();
    cout<<s1.size()<<endl;
    cout<<s2.length()<<endl;
    cout<<s3.capacity()<<endl;
    cout<<s2.at(3)<<endl;
    cout<<s1.data()<<endl;
    cout<<s3.append('e')<<endl;
    cout<<s2.c_str()<<endl;
    s3.pop_balck();
    cout<<s3<<endl;
    s3.push_back('.');
    cout<<s3<<endl;
    Mystring s4="ssr";
    s4+="'a'";
    cout<<s4<<endl;
    Mystring s5;
    cout<<"请输入:";
    cin>>s5;
    cout<<s5<<endl;
    cout<<(s5>=s3)<<endl;
    return 0;
}

结果:

思维导图:

相关推荐
m0_738355695 分钟前
java泛型
java·开发语言
CodeJourney.11 分钟前
EndNote与Word关联:科研写作的高效助力
数据库·人工智能·算法·架构
大模型铲屎官21 分钟前
哈希表入门到精通:从原理到 Python 实现全解析
开发语言·数据结构·python·算法·哈希算法·哈希表
C语言扫地僧37 分钟前
RPC 框架项目剖析
c++·网络协议·学习·rpc
L_090738 分钟前
【C】队列与栈的相互转换
c语言·开发语言·数据结构
果壳中的robot38 分钟前
【ORB-SLAM3】鲁棒核函数的阈值设置
算法·计算机视觉·机器人
qq4054251971 小时前
基于python的旅客游记和轨迹分析可视化系统设计(新)
开发语言·python
C#Thread1 小时前
C#上位机--进程和线程的区别
java·开发语言
DKPT1 小时前
计算机网络之路由协议(自治系统)
开发语言·笔记·学习·计算机网络·算法
水月梦镜花1 小时前
数据结构:基数排序(c++实现)
开发语言·数据结构·c++