(C语言)常见的字符串与内存操作函数

问:

1. Solve the problems:我想用三种方法求字符串的长度怎么办?

2. strlen处理的字符串中有什么时需要注意:什么只记为什么?当什么不起什么作用时,什么不计算在内,编译器会把什么,什么,什么或者什么当成什么,strlen碰到什么就会怎么样,而什么无影响?

3. Solve the problems:我想实现两个字符串拷贝怎么办?

4. Solve the problems:我想实现两个字符串拼接怎么办?

5. Solve the problems:我想实现两个字符串比较怎么办?

6. Solve the problems:如何判断一个字符串是不是另外一个字符串的子字符串?

7. Slove the problems:如何把字符串"Elon Musk&Telsa:SpaceX@C++"肢解成"Elon Musk","Telsa","SpaceX","C++"分别打印出来呢?

8. 由于什么会怎么样,因此用什么进行什么的字符串一般都是什么?

9. Solve the problems:我想设计一个密码登录器,要求:密码必须有大写字母≥2个,小写字母≥3个,数字≥3个,长度≤20,不得含有敏感词汇“Elon Musk”,该怎么写?

10. Solve the problems:报刊头标arr : “Elon Musk Is A Great Successful Person! ”如何将Is的I改成小写,并且后面全部大写?

11. Solve the problems:我想把内存数据(不受数据类型限制)直接无脑拷贝到另一个内存区域,该怎么办?

12. Solve the problems:上述情况下两块内存区域有重叠,该怎么办?

13. Solve the problems:我想要把学生结构体的成员年龄初始化为0,成绩初始化为0,姓名字符初始化为*,该怎么办?


答:

//1
size_t my_strlen(const char* str)
{
    assert(str);
    size_t count = 0;
    while (*str)
    {
        count++;
        str++;
    }
    return count;
}


//2
size_t my_strlen(const char* str)
{
    assert(str);
    if (*str)
    {
        return my_strlen(str + 1) + 1;
    }
    else
    {
        return 0;
    }
}


//3
size_t my_strlen(const char* str)
{
    assert(str);
    const char* start = str;
    while (*str)
    {
        str++;
    }
    return str - start;
}
  1. 转义字符,转义字符整体,一个字符,\,转义,\本身,\0,\00,\000,\x000....,\0,停下来,sizeof。

//解决方法
char* my_strcpy(char* dest, const char* src)
{
    assert(dest && src);
    char* ret = (char*)dest;
    while (*dest++ = *src++)
    {
        ;
    }
    return ret;
}
//解决方法
char* my_strcat(char* dest, const char* src)
{
    assert(dest && src);
    char* ret = (char*)dest;
    while (*dest)
    {
        dest++;
    }
    while (*dest++ = *src++)
    {
        ;
    }
    return ret;
}
//解决方法
int my_strcmp(const char* str1, const char* str2)
{
    assert(str1 && str2);
    while (*str1 == *str2)
    {
        if (*str1 == '\0')
        {
            return 0;
        }
        str1++;
        str2++;
    }
    if (*str1 > *str2)
    {
        return 1;
    }
    else
    {
        return -1;
    }
}
//解决方法
char* my_strstr(const char* str1, const char* str2)
{
    assert(str1 && str2);
    if (*str2 == '\0')
        return (char*)str1;
    char* s1 = NULL;
    char* s2 = NULL;
    char* cp = (char*)str1;
    while (*cp)
    {
        s1 = cp;
        s2 = str2;
        while (*s1 == *s2)
        {
            s1++;
            s2++;
            if (*s2 == '\0')
            {
                return cp;
            }
        }
        cp++;
    }
    return NULL;
}
//解决方法
int main()
{
    char str[30] = "Elon Musk&Telsa:SpaceX@C++";
    char* sep = "&:@";
    for (char* ret = strtok(str, sep); ret != NULL; ret = strtok(NULL, sep))
    {
        printf("%s\n", ret);
    }
    return 0;
}
  1. strtok函数,改变被操作的字符串,strtok,切分,临时拷贝的备份。

//解决方法
#include <ctype.h>
#define PASSWORD_MAX 30
int JudgePassword(const char* password)
{
    int flag1 = 0;
    int flag2 = 0;
    int flag3 = 0;
    int sz = strlen(password);
    if (sz >= 30 || strstr(password, "ElonMusk") != NULL)
        return 0;
    int i = 0;
    for (i = 0; i < sz; i++)
    {
        if (islower(password[i]))
            flag1++;
        else if (isupper(password[i]))
            flag2++;
        else if (isdigit(password[i]))
            flag3++;
        if (flag1 >= 3 && flag2 >= 2 && flag3 >= 3)
            return 1;
    }
    return 0;
}
int main()
{
    printf("请输入密码:");
    char password[PASSWORD_MAX] = { 0 };
    while (gets(password) != EOF)
    {
        if (JudgePassword(password))
        {
            printf("密码已经设置成功!\n");
            break;
        }
        printf("不符合规定,重新设置:");
    }
    return 0;
}
//解决方法
#include <ctype.h>
void Change(char* p)
{
    while (*p)
    {
        if (islower(*p))
        {
            *p = toupper(*p);
        }
        p++;
    }
}
int main()
{
    char arr[50] = "Elon Musk Is A Great Successful Person ! ";
    int i = 0;
    while (*(arr + i))
    {
        if (*(arr + i) == 'I')
            *(arr + i) = 'i';
        if (*(arr + i) == 'A')
        {
            Change(arr + i);
            break;
        }
        i++;
    }
    printf("%s\n", arr);
    return 0;
}
void* my_memcpy(void* dest, const void* src, size_t num)
{
    assert(dest && src);
    void* ret = dest;
    int i = 0;
    for (i = 0; i < num; i++)
    {
        *((char*)dest) = *((char*)src);
        ((char*)src)++;
        ((char*)dest)++;
    }
    return ret;
}
//解决方法
void* my_memmove(void* dest, const void* src, size_t num)
{
    assert(dest && src);
    void* ret = dest;
    if (src < dest)
    {
        while (num--)
        {
            *((char*)dest + num) = *((char*)src + num);
        }
    }
    else
    {
        while (num--)
        {
            *((char*)dest) = *((char*)src);
            src = (char*)src + 1;
            dest = (char*)dest + 1;
        }
    }
    return ret;
}
struct Stu
{
    char name[10];
    int age;
    float score;
}s1;
int main()
{
    struct Stu* ps1 = &s1;
    memset(&(ps1->name), '*', sizeof(ps1->name));
    memset(&(ps1->age), 0, sizeof(ps1->age));
    memset(&(ps1->score), 0, sizeof(ps1->score));
    printf("%s %d %.2lf", s1.name, s1.age, s1.score);
    return 0;
}

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

絕知此事要躬行

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值