设计一个字符串类,并将字符串处理函数的内容进行封装

#include<iostream>
using namespace std;
class String {

public:
    //定义类的成员变量
    char s[10] = "abcd";
    char *ps = s;

    const char t[10] = "dcba";
    const char *pt = t;

    char S[10] = "ABCDEF";

//构造函数部分
    String();
    String(const String & c);

//字符串处理函数
    //连接
    void strcat();
    //复制
    void strcpy();
    //复制n个
    void strcpy(int n);
    //比较
    int strcmp();
    //取长度
    int strlen( char *s);
    //转大小写
    void strwr( char *s);
    void strup( char *s);

    ~String();
};

String::~String()
{
}

String::String()
{
}
//拷贝函数
String::String(const String & c) {  //由于是拷贝,所以把参数用const限定
    const char* s = c.s;
    cout << "1";
};

void String::strcat()
{
    while (*ps) {  //把指针移动到最后
        ++ps;
    }

    while (*pt) {  //当*pt有值  就进入
        *ps = *pt;  //复制
        ++pt;  //指针后移
        ++ps;
    }
    cout << s << endl;  //输出下连接复制是否正确
    return;
}

void String::strcpy()
{
    while ((*ps = *pt) != ‘\0‘) { //一直到*pt指向的内容为\0就跳出
        ps++;  //往后移动指针
        pt++;
    }
    *ps = *pt;  //把\0也给*ps
    cout << s << endl;
    return;
}

void String::strcpy(int n) //复制前n个
{
    int i = 0;
    while (*pt) {  //首先也要判断pt有值
        if (i<n) {
            *ps = *pt;
            ++i;
            ps++;
            pt++;
        }
        else {   //如果已经复制了n个 那就结束
            break;
        }
    }
    //结束复制之后要 最后加空字符
        *ps = ‘\0‘;

    cout << s << endl;
    return;
}

int String::strcmp()
{
    //用for循环  找到不相等的地方
    for (; *ps == *pt; ++ps, ++pt) {
        if (*ps == ‘\0‘) { //如果两个完全相等 会进去
            return 0;
        }
    }
    return (*ps - *pt);
    //返回当前指的位置 相减 就是字符对应的数值相减
}

int String::strlen( char * s)
{
    int i = 0;
    while (*s) { //计算的有效长度(不加空字符)
        ++s;
        ++i;
    }
    return i;

}

void String::strwr( char * s)
{
     char*m = s;
    while (*s)
    {   //要判断是否为大写字母
        if (*s >= ‘A‘&&*s <= ‘Z‘) {
            *s += 32;
        }
        ++s;
    }
    //由于指针已经把 类里面的成员S  变为小写
    //故直接输出就可以验证
    cout << S << endl;
    return;
}

void String::strup( char * s)
{
     char*m = s;
    while (*s)
    {
        if (*s >= ‘a‘&&*s <= ‘z‘) {
            *s -= 32;
        }
        ++s;
    }
    cout << S << endl;
    return;
}
void main()
{
    //调用函数
    cout << "strcat:" << endl;
    String e1;
    e1.strcat();
    cout << endl;

    cout << "strcpy:" << endl;
    String e2;
    e2.strcpy();

    cout << endl;

    cout << "strncpy:" << endl;
    String e3;
    e3.strcpy(3);

    cout << endl;

    String e4;
    cout << "strcmp:" << endl << e4.strcmp() << endl;
    cout << endl;

    String e5;
    cout << "strlen:" << endl << e5.strlen(e5.s) << endl;
    cout << endl;

    cout << "strwr:" << endl;
    String e6;
    e6.strwr(e6.S);
    cout << endl;

    cout << "strup:" << endl;
    String e7;
    e7.strup(e6.S);
    cout << endl;

    system("pause");
    return;
}

原文地址:https://www.cnblogs.com/Stephen-Jixing/p/9866714.html

时间: 2024-10-12 11:53:08

设计一个字符串类,并将字符串处理函数的内容进行封装的相关文章

oc 文件管理NSFileManager,文件读写NSFileHandle ,设计一个文件管理类将一个文件复制到另一个文件,由于文件过大要求每次复制100长度,通过NSFileHandle 来操作,并

设计一个文件管理类将一个文件复制到另一个文件,由于文件过大要求每次复制100长度,通过NSFileHandle来操作,并通过代理模式打印出当前的赋值进度百分比 main.m #import <Foundation/Foundation.h> #import "FileMaker.h" int main(int argc,const char * argv[]) { @autoreleasepool { NSString * fromPath = [NSHomeDirecto

设计一个Bank类,银行某账号的资金往来账管理

设计一个Bank类,实现银行某账号的资金往来账管理,包括建账号.存入.取出等.Bank类包括私有数据成员top(当前指针).date(日期).money(金额).rest(余额)和sum(累计余额).另有一个构造函数和3个成员函数bankinO(处理存入账).bankout()(处理取出账)和disp( )(出明细账). [知识点]:2.2  2.3 [参考分]:25分 [难易度]:B 实现案例: /* 2017年8月19日23:03:58 */ #include<iostream> clas

Java基础-继承-编写一个Java应用程序,设计一个汽车类Vehicle,包含的属性有车轮个数 wheels和车重weight。小车类Car是Vehicle的子类,其中包含的属性有载人数 loader。卡车类Truck是Car类的子类,其中包含的属性有载重量payload。每个 类都有构造方法和输出相关数据的方法。最后,写一个测试类来测试这些类的功 能。

#29.编写一个Java应用程序,设计一个汽车类Vehicle,包含的属性有车轮个数 wheels和车重weight.小车类Car是Vehicle的子类,其中包含的属性有载人数 loader.卡车类Truck是Car类的子类,其中包含的属性有载重量payload.每个 类都有构造方法和输出相关数据的方法.最后,写一个测试类来测试这些类的功 能. package hanqi; public class Vehicle { private int wheels; private int weight

设计一个学生类&amp;班级类

第一题 设计一个学生类 属性:姓名.学号.年龄.成绩 设计一个班级类要求:实现向班级中添加学生.删除学生.查看学生.按照指定条件排序 属性:班级代号,所有学生 需要使用 calss, __int__, __str__, sort, append, dict, list, remove, for in class Stu: # 设置学生基础属性 def __init__(self, name, num, age, cj): self.name = name self.num = num self.

类与对象 设计一个Dog类

题目内容: 设计一个Dog类,包含name.age.sex和weight等属性以及对这些属性操作的方法.实现并测试这个类.根据类的封装性要求,把name.age.sex和weight声明为私有的数据成员,编写公有成员函数setdata()对数据进行初始化,GetName().GetAge().GetSex()和GetWeight()获取相应属性.初始化数据由用户输入. 输入格式: Dog类对象的初始化数据 输出格式: 根据Dog类对象的初始化数据输出一句话,请严格按照格式输出,句末有点号. 输入

6-1 设计一个矩形类Rectangle (10分)

设计一个名为Rectangle的类表示矩形.这个类包括: 两个名为width和height的double型数据域,它们分别表示矩形的宽和高.width和height的默认值都为1. 一个无参构造方法. 一个为width和height指定值的矩形构造方法. 一个名为getArea()的方法返回这个矩形的面积. 一个名为getPerimeter()的方法返回这个矩形的周长. 类名为: Rectangle 裁判测试程序样例: import java.util.Scanner; /* 你的代码将被嵌入到

P1308(字符串类,处理字符串查找)

题目描述 一般的文本编辑器都有查找单词的功能,该功能可以快速定位特定单词在文章中的位置,有的还能统计出特定单词在文章中出现的次数. 现在,请你编程实现这一功能,具体要求是:给定一个单词,请你输出它在给定的文章中出现的次数和第一次出现的位置.注意:匹配单词时,不区分大小写,但要求完全匹配,即给定单词必须与文章中的某一独立单词在不区分大小写的情况下完全相同(参见样例1 ),如果给定单词仅是文章中某一单词的一部分则不算匹配(参见样例2 ). 输入格式 共22行. 第11行为一个字符串,其中只含字母,表

如何设计一个模板类

1. 示例 1 #include <vector> 2 3 using std::vector; 4 // ------------------------------------------------------------------------------- 5 template <class T> 6 class TVector { 7 private: 8 vector<T> m_stackData; 9 vector<T> m_stackMin

(1)定义一个接口Compute含有一个方法int computer(int n,int m); (2)设计四个类分别实现此接口,完成+-*/运算 (3)设计一个类UseCompute,含有方法: public void useCom(Compute com, int one, int two) (4)设计一个测试类

package b; public interface Computer { int computer(int n,int m); } package b; public class Jia implements Computer { @Override public int computer(int n, int m) { int jia; jia=m+n; System.out.println(m+"+"+n+"="+jia); return jia; } }