博客
关于我
码图:156 扩展String类(C++)
阅读量:378 次
发布时间:2019-03-05

本文共 2359 字,大约阅读时间需要 7 分钟。

扩展String类,引入头文件CString.h,它的内容如下:

#include 
using namespace std;class String {protected: char *mystr; int len;public: String(const char *p) { len = strlen(p); mystr = new char[len + 1]; strcpy(mystr, p); } ~String() { if (mystr != NULL) { delete[] mystr; mystr = NULL; len = 0; } } void showStr() { cout << mystr << endl; }};

实现int IsSubString(int start, const char *str):

int EditString::IsSubString(int start, const char *str) {    int i, j;    for (i = 0; i < len; i++) {        int k = start + i;        for (j = 0; str[j] != '\0'; j++, k++) {            if (str[j] != mystr[k]) break;        }        if (str[j] == '\0') return start + i;    }    return -1;}

实现void EditChar(char s, char d):

void EditString::EditChar(char s, char d) {    int i = 0;    while (mystr[i]) {        if (mystr[i] == s) {            mystr[i] = d;        }        i++;    }}

实现void EditSub(char * subs, char * subd):

void EditString::EditSub(const char *subs, const char *subd) {    int i, j, len_s = strlen(subs), len_d = strlen(subd);    for (i = 0; i < len; i++) {        int k = i;        for (j = 0; subs[j] != '\0'; j++, k++) {            if (subs[j] != mystr[k]) break;        }        if (subs[j] == '\0') {            int m = i + len_s;            while (mystr[m - 1]) {                mystr[m + len_d - len_s] = mystr[m];                m++;            }            m = 0;            while (subd[m]) {                mystr[i + m] = subd[m];                m++;            }            i += (len_d - 1);        }    }}

实现void DeleteChar(char ch):

void EditString::DeleteChar(char ch) {    int i = 0;    while (mystr[i]) {        while (mystr[i] == ch) {            int j = i;            while (mystr[j]) {                mystr[j] = mystr[j + 1];                j++;            }        }        i++;    }}

实现void DeleteSub(const char *sub):

void EditString::DeleteSub(const char *sub) {    int i, j;    for (i = 0; i < len; i++) {        int k = i;        for (j = 0; sub[j] != '\0'; j++, k++) {            if (sub[j] != mystr[k]) break;        }        if (sub[j] == '\0') {            int len = strlen(sub);            int m = i + len;            while (mystr[m - 1]) {                mystr[m - len] = mystr[m];                m++;            }        }    }}

转载地址:http://ivqg.baihongyu.com/

你可能感兴趣的文章
nvidia 各种卡
查看>>
Nvidia 系列显卡大解析 B100、A40、A100、A800、H100、H800、V100 该如何选择,各自的配置详细与架构详细介绍,分别运用于哪些项目场景
查看>>
NVIDIA-cuda-cudnn下载地址
查看>>
nvidia-htop 使用教程
查看>>
nvidia-smi 参数详解
查看>>
Nvidia驱动失效,采用官方的方法重装更快
查看>>
nvmw安装node-v4.0.0之后版本的临时解决办法
查看>>
nvm切换node版本
查看>>
nvm安装 出现 Error retrieving “http://xxxx/SHASUMS256.txt“: HTTP Status 404 解决方法
查看>>
nvm安装以后,node -v npm 等命令提示不是内部或外部命令 node多版本控制管理 node多版本随意切换
查看>>
NXLog采集windows日志配置conf文件
查看>>
ny540 奇怪的排序 简单题
查看>>
NYOJ -216 A problem is easy
查看>>
NYOJ 1066 CO-PRIME(数论)
查看>>
NYOJ 737:石子合并(一)(区间dp)
查看>>
nyoj 91 阶乘之和(贪心)
查看>>
nyoj------203三国志
查看>>
NYOJ-525 一道水题
查看>>
NYOJ127星际之门(一)
查看>>
nyoj58 最少步数
查看>>