博客
关于我
码图: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/

你可能感兴趣的文章
Objective-C实现all combinations所有组合算法(附完整源码)
查看>>
Objective-C实现all permutations所有排列算法(附完整源码)
查看>>
Objective-C实现all subsequences所有子序列算法(附完整源码)
查看>>
Objective-C实现AlphaNumericalSort字母数字排序算法(附完整源码)
查看>>
Objective-C实现alternate disjoint set不相交集算法(附完整源码)
查看>>
Objective-C实现alternative list arrange备选列表排列算法(附完整源码)
查看>>
Objective-C实现An Armstrong number阿姆斯特朗数算法(附完整源码)
查看>>
Objective-C实现anagrams字谜算法(附完整源码)
查看>>
Objective-C实现ApproximationMonteCarlo蒙特卡洛方法计算pi值算法 (附完整源码)
查看>>
Objective-C实现area under curve曲线下面积算法(附完整源码)
查看>>
Objective-C实现arithmetic算术算法(附完整源码)
查看>>
Objective-C实现armstrong numbers阿姆斯壮数算法(附完整源码)
查看>>
Objective-C实现articulation-points(关键点)(割点)算法(附完整源码)
查看>>
Objective-C实现atoi函数功能(附完整源码)
查看>>
Objective-C实现average absolute deviation平均绝对偏差算法(附完整源码)
查看>>
Objective-C实现average mean平均数算法(附完整源码)
查看>>
Objective-C实现average median平均中位数算法(附完整源码)
查看>>
Objective-C实现average mode平均模式算法(附完整源码)
查看>>
Objective-C实现avl 树算法(附完整源码)
查看>>
Objective-C实现AvlTree树算法(附完整源码)
查看>>