寒假学习(7)(C语言7+模数电7)

cpp 复制代码
#include <stdio.h>
#include <string.h>
 
int main()
{
    //strspn函数怎么用
    //函数说明:
    //strspn函数返回字符串str1中第一个不在字符串str2中出现的字符下标。
    char *str = "123456789";
    char *str2 = "23";
    printf("%d\n", strspn(str, str2));
 
    return 0;
}
一键获取完整项目代码
cpp

#include <stdio.h>
#include <string.h>
 
int main()
 
{
    #if 0
    //strstr函数怎么用
 
    //函数说明:
 
    //strstr函数返回字符串str2在字符串str1中第一次出现的位置。
 
    char *str = "123456789";
 
    char *str2 = "23";
 
    printf("%s\n", strstr(str, str2));
    #endif
 
    //使用strstr函数统计字串的个数
    char *str = "123223323423";
    char *str2 = "23";
    int count = 0;
    char *p = str;
 
    while(p!=NULL)
    {
        p = strstr(p, str2);
        if(p!=NULL)
        {
            count++;
            p += strlen(str2);
        }
    }
 
    // while ((p = strstr(p, str2)) != NULL)
    // {
    //     count++;
    //     p += strlen(str2);
    // }
    printf("%d\n", count);
 
    return 0;
 
}
cpp 复制代码
#include <stdio.h>
#include <string.h>
 
int main()
{
    //strtok函数怎么用
    //函数说明:
    //strtok函数将字符串str1分割成由字符串str2分割的多个部分,并返回分割后的第一个部分。
    char str[] = "i am from china";  // 使用数组而非字符串字面量,允许修改
    char *delim = " ";  // 分隔符字符串
 
    char *result = strtok(str, delim);
 
    while (result != NULL)
    {  // 检查返回值
        printf("%s\n", result);
        result = strtok(NULL, delim);  // 继续分割
    }
    
 
    return 0;
}
cpp 复制代码
#include <stdio.h>
#include <string.h>
//实现strtok_r函数
char* strtok_r(char* str, const char* delim, char** saveptr)
{
 
    if (str == NULL)
    {
        str = *saveptr;
    }
    
    if (str == NULL)
    {
        return NULL;    
    }
 
    while(delim != NULL)
    {
        if (*delim == *str)
        {
            *str = '\0';
            *saveptr = str + 1;
            return str;
        }
        delim++;
    }
    
}
 
int main()
{
    char str[] = "i am from china";  // 使用数组而非字符串字面量,允许修改
    char *delim = " ";  // 分隔符字符串
 
    char *saveptr = NULL;
 
    char *result = strtok_r(str, delim, &saveptr);
 
    while (result != NULL)
    {  // 检查返回值
        printf("%s\n", result);
        result = strtok_r(NULL, delim ,&saveptr);  // 继续分割
    }
 
    return 0;
}
cpp 复制代码
#include  <stdio.h>
 
int add(int a, int b)
 
{
 
    return a + b;
 
}
 
int main()
{
    //函数指针的作用
    //函数指针是指向函数的指针,可以通过函数指针调用函数。
    int (*p)(int, int) = add;
    printf("%d\n", p(1, 2));
    //1.隐藏接口
    //2. 间接体现多态
 
    return 0;
}
cpp 复制代码
#include <stdio.h>
int add(int a, int b)
{
    return a + b;
}
int sub(int a, int b)
{
    return a - b;
}
int mul(int a, int b)
{
    return a * b;
}
 
int main()
{
    //函数指针数组怎么用
    //函数指针数组是指一个数组,数组中的每个元素都是一个函数指针。
    int (*p[3])(int, int) = {add, sub, mul};
    printf("%d\n", p[0](1, 2));
    printf("%d\n", p[1](1, 2));
    printf("%d\n", p[2](1, 2));
 
    return 0;
 
}
cpp 复制代码
#include <stdio.h>
//什么是可变参数
 
/**
 * 实现原理
 * 变量压栈是连续的 
 * C语言提供了三个宏定义
 * va_start(ap, n) 初始化ap
 * va_arg(ap, type) 获取参数
 * va_end(ap) 结束
 */
#include <stdarg.h>
 
int add(int n, ...)
//以一个参数n表示可变参数的个数
 
{
    int sum = 0;
 
    va_list ap;
 
    va_start(ap, n);
 
    for (int i = 0; i < n; i++)
 
    {
 
        sum += va_arg(ap, int);
 
    }
 
    va_end(ap);
 
    return sum;
 
}
 
int main()
 
{
 
    //可变参数怎么用
 
    //可变参数是指一个函数可以接收任意个数的参数。
 
    printf("%d\n", add(3, 1, 2, 3));
 
    return 0;
}
相关推荐
BothSavage21 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn21 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽1 天前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说2 天前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰2 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术2 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六2 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术2 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize2 天前
初识DFS 与 BFS:递归、队列与图遍历
算法