自编String类型(C++)

设计思路:

  • 首先自己编写了左移运算符的重载,方便后续测试时输出该String类
    • 对于to_lower_case函数,遍历字符串,并修改所有大写字母。
    • 对于to_int函数,从头向尾遍历字符串,将每个数字字符转化为数字,并增加到乘以10倍的num变量上,最后返回num。
    • 对于remove_spaces函数,遍历字符串,维护两个指针,指针i遍历字符串,对于所有非空格字符串,将str[i]赋值给str[j],并执行j++操作。
    • 对于find_replace_str函数,构建循环结构。对于每一次循环,调用strstr找到子串的位置,调用memmove函数对源字符串中字串后的部分进行平移,预留出能够放下替代串的长度,之后调用memcpy函数将替代串拷贝进如源字符串。
    • 对于substring函数可以首先用p指针找到start的位置,然后调用strncpy函数
    • 对于is_substring函数可以调用<cstring>库中的strstr函数判断。

 代码实现:
 

#include<iostream>
#include<cstring>
#include<cstdlib>
using namespace std;
class String
{friend ostream& operator<<(ostream& cout,String& s);char* str;
public:String(){str=NULL;}String(const char* p){str=new char(strlen(p)+1);strcpy(str,p);}~String(){delete[] str;str=NULL;}int length(){return strlen(str);}char &char_at(int i){if(i<0||i>=strlen(str)){cout<<"超出字符串范围!"<<endl;exit(-1);}return str[i];}const char* get_str(){return str;}String &copy(const char* p){delete []str;str=new char(strlen(p)+1);strcpy(str,p);return *this;}String &copy(const String& s){return copy(s.str);}String &append(const char* p){char* p1=new char(strlen(str)+strlen(p)+1);strcpy(p1,str);strcat(p1,p);delete []str;str=p1;return *this;}String &append(const String& s){return append(s.str);}int compare(const char* p){return strcmp(str,p);}int compare(const String& s){return strcmp(str,s.str);}bool is_substring(const char* sub_str){return strstr(str,sub_str)!=NULL;}bool is_substring(const String& s){return strstr(str,s.str)!=NULL;}String substring(int start,int len){String s;if(start<0||len<=0||start>=strlen(str))return s;char* p=str;for(int i=0;i<start;i++)p++;s.str=new char(len);strncpy(s.str,p,len);return s;}int find_replace_str(const char* find_str,const char* replace_str){int f_len=strlen(find_str);int r_len=strlen(replace_str);int Count=0;char* pos=str;while((pos=strstr(pos,find_str))!=nullptr){memmove(pos+r_len,pos+f_len,strlen(pos+f_len)+1);memcpy(pos,replace_str,strlen(replace_str));pos+=r_len;Count++;}return Count;}void remove_spaces(){int l=strlen(str);int j=0;for(int i=0;i<l;i++){if(str[i]!=' ')str[j++]=str[i];}str[j]='\0';}int to_int(){int sum=0;int l=strlen(str);for(int i=0;i<l;i++){if(str[i]>='0'&&str[i]<='9'){sum*=10;sum+=str[i]-'0';}}return sum;}void to_lower_case(){int l=strlen(str);for(int i=0;i<l;i++){if(str[i]>='A'&&str[i]<='Z'){str[i]='a'+str[i]-'A';}}}
};
ostream& operator<<(ostream& cout,String& s)
{cout<<s.str;return cout;
}
void test1();
void test2();
int main()
{test2();return 0;
}
void test1()
{String s1;String s2("abc DEFG abc");s1.copy("xyz");String s3=("abc");cout<<"s1: "<<s1<<endl;cout<<"s2: "<<s2<<endl;cout<<"s3: "<<s3<<endl;if(s2.is_substring(s1))cout<<"s1 is s2's substring"<<endl;else cout<<"s1 is not s2's substring"<<endl;if(s2.is_substring(s3))cout<<"s3 is s2's substring"<<endl;else cout<<"s3 is not s2's substring"<<endl;String s4=s2.substring(0,3);cout<<"s2.substring(0,3): "<<s4<<endl;int num=s2.find_replace_str("abc","xyz");cout<<"num of abc in s2:"<<num<<endl;cout<<"s2 replace abc with xyz: "<<s2<<endl;s2.remove_spaces();cout<<"s2 without spaces: "<<s2<<endl;s2.to_lower_case();cout<<"s2 to lower case: "<<s2<<endl;s4.copy("123");cout<<"s4: "<<s4<<" to int:"<<s4.to_int()<<endl;
}
void test2()
{String s0=("abc efgh abc");s0.find_replace_str("ab","ijk");cout<<s0<<endl;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/6136.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

从字符串到序列:Jinja2 过滤器的终极指南(Jinja2 filter过滤器的使用方法整理与总结)

文章目录 📖 介绍 📖🏡 演示环境 🏡📒 过滤器 📒📝 字符串过滤器📝 数字过滤器📝 列表和序列过滤器📝 字典过滤器📝 自定义过滤器🎈 演示示例🎈📝 字符串过滤器📝 数字过滤器📝 列表和序列过滤器📝 字典过滤器📝 自定义过滤器

数组的扩容与缩容

数组的扩容与缩容 文章目录 数组的扩容与缩容数组的扩容内存分析 数组的缩容内存分析内存分析 数组的扩容 数组扩容是指当原有数组的空间不足以容纳更多的元素时&#xff0c;创建一个新的、长度更大的数组&#xff0c;并将原数组中的元素复制到新数组中&#xff0c;然后更新原…

ubuntu 24.04 向日葵桌面版安装

向日葵桌面版 ubuntu24.04向日葵无法安装&#xff0c;缺少依赖。向日葵缺少依赖&#xff0c;“有未能满足的依赖关系”。解决方案。 1. 下载本体 mkdir oraysun && cd oraysun wget https://d.oray.com/sunlogin/linux/SunloginClient_15.2.0.63062_amd64.deb2. 下载…

iOS 创建开源库时如何使用图片和xib资源

参考文章 参考文章 使用xib的正确姿势 #define MAIN_BUNDLE [NSBundle bundleForClass:[self class]] //获取bundle [[MAIN_BUNDLE loadNibNamed:itemResuableStr owner:self options:nil] lastObject]; //加载xib [tempCollectionView registerNib:[UINib nibWithNibName…

Word文件后缀

Word文件后缀 .docx文件为Microsoft Word文档后缀名&#xff0c;基于XML文件格式 .dotm为Word启用了宏的模板 .dotx为Word模板 .doc为Word97-2003文档&#xff0c;二进制文件格式 参考链接 Word、Excel 和 PowerPoint 的文件格式参考 Learn Microsoft

类和对象【四】运算符重载

文章目录 运算符重载的概念运算符重载&#xff08;函数&#xff09;返回值类型&#xff1a;任意类型函数名&#xff1a;operator已有操作符 运算符重载&#xff08;函数&#xff09;的特点和注意点3个比较特殊的运算符重载赋值运算符&#xff08;&#xff09;重载返回值类型和返…

嵌入式开发四:STM32 基础知识入门

为方便更好的学习STM32单片机&#xff0c;本篇博客主要总结STM32的入门基础知识&#xff0c;重点在于理解寄存器以及存储器映射和寄存器映射&#xff0c;深刻体会STM32是如何组织和管理庞大的寄存器&#xff0c;从而提高开发效率的&#xff0c;为后面的基于标准库的开发做好铺垫…

基于SSM框架的个人博客系统设计与实现:技术总结

引言 在数字化时代&#xff0c;个人博客系统已成为展示个人技术见解、分享生活点滴的重要平台。本次博客介绍了一个基于Java的个人博客系统的设计与实现&#xff0c;采用了流行的SSM&#xff08;Spring、SpringMVC、MyBatis&#xff09;技术栈&#xff0c;以及MySQL数据库和JS…

宝兰德数据可视化软件顺应AI趋势,释放数据价值的无限可能

随着数字技术的持续创新和普及&#xff0c;社会治理方式、产业形态、生活方式高度数字化&#xff0c;由此催生海量数据&#xff0c; 这些数据不仅种类繁多&#xff0c;且具有很高的价值。当企业决策者认识到这些数量庞大、晦涩难懂的数据背后蕴含着巨大的商业价值时&#xff0c…

MySQL 8.4 版本(LTS) 发布,一睹为快

前言 Oracle 前几天发布了 MySQL 8.4 版本(LTS)&#xff0c; 该版本是创新版的第一个长期支持版本。详细规划&#xff0c;请移步 技术译文 | 一文了解 MySQL 全新版本模型 关于 MySQL 的版本发布规划 Oracle MySQL 官方开发团队推出的新版本将过渡到新的 MySQL 版本模型。MyS…

cefsharp实现资源替换如网页背景、移除替换标签、html标识、执行javascript脚本学习笔记(含源码说明)

(一)实现测试(仅供学习参考) 1.1 目标系统页面(登录页)和登录后首页面中2处(一个替换一个移除) 1.2 实现后效果(使用cefsharp自定义浏览器实现以上功能) 1.3 登录后页面替换和移除 系统名称和一个功能菜单li (二)通过分析代码实现脚本编写 2.1 分开处理,设置了…

IDEA 2022.1版本开始,可以直接运行Markdown里的命令行

参照这种格式&#xff1a; shell mvn clean install注意idea支持的版本&#xff1a;是从 2022.1版本开始的。 ps&#xff1a;之前有人写过了&#xff0c;感觉很实用但是蛮多开发者不一定会知道的功能。 参考资料&#xff1a; https://www.cnblogs.com/didispace/p/16144107.h…

pygame鼠标绘制

pygame鼠标绘制 Pygame鼠标绘制效果代码 Pygame Pygame是一个开源的Python库&#xff0c;专为电子游戏开发而设计。它建立在SDL&#xff08;Simple DirectMedia Layer&#xff09;的基础上&#xff0c;允许开发者使用Python这种高级语言来实时开发电子游戏&#xff0c;而无需被…

LeetCode刷题笔记第168题:Excel表列名称

LeetCode刷题笔记第168题&#xff1a;Excel表列名称 题目&#xff1a; 给你一个整数 columnNumber &#xff0c;返回它在 Excel 表中相对应的列名称。 例如&#xff1a; A -> 1 B -> 2 C -> 3 … Z -> 26 AA -> 27 AB -> 28 … 想法&#xff1a; 类似十…

Spring Boot可以同时处理多少请求?

Spring Boot本身对并发请求的处理能力没有明确的限制。Spring Boot的并发处理能力通常受到以下因素影响&#xff1a; 服务器硬件&#xff1a;包括CPU核心数、内存大小等。JVM配置&#xff1a;堆内存、永久代或元空间大小等。Web服务器&#xff1a;Spring Boot 默认使用嵌入式的…

ES数据存储与查询基本原理

Elasticsearch&#xff08;ES&#xff09;简介 Elasticsearch&#xff08;ES&#xff09;是一个分布式、可扩展、近实时的搜索和分析引擎&#xff0c;它基于Lucene&#xff0c;设计用于云计算中&#xff0c;处理大规模文档检索和数据分析任务&#xff0c;常用于实现内部搜索引…

CMake:静态库链接其他动态库或静态库(九)

1、项目结构 对于下面这样一个项目 把calc模块做成静态或者动态库把sort模块做成静态库然后再sort模块中的*.cpp调用calc模块生成的库即可&#xff08;这样就制作了一个静态库引用动态或者静态库&#xff09;test模块用于测试sort模块中的内容 . ├── calc │ ├── ad…

Codeforces Round 943 (Div. 3) 题解 缺F和G2

A题&#xff1a; Maximize? 题目大意&#xff1a; 给你一个整数 x&#xff0c; 要求你找出任意一个 y &#xff0c;。使得最大。 思路一&#xff1a;暴力 数据范围小&#xff0c;直接暴力。 #include <bits/stdc.h> #define int long long #define endl \n using n…

MySQL —— 库的基本操作

一、数据库的增删查改 &#xff08;1&#xff09;创建 语句&#xff1a;create database db_name;&#xff08;db_name是自定义的数据库名字&#xff09; &#xff08;2&#xff09;删除 语句&#xff1a;drop database dp_name;&#xff08;dp_name是要被删除的数据库的名字…

【智能算法】冠豪猪优化算法(CPO)原理及实现

目录 1.背景2.算法原理2.1算法思想2.2算法过程 3.结果展示4.参考文献5.代码获取 1.背景 2024年&#xff0c;M Abdel-Basset等人受到冠豪猪防御行为启发&#xff0c;提出了冠豪猪优化算法&#xff08;Crested Porcupine Optimizer, CPO&#xff09;。 2.算法原理 2.1算法思想 …