[C语言][PTA基础C基础题目集] strtok 函数的理解与应用

一.strtok函数的解释与说明

①strtok函数的功能

Find the next token in a string.

 即查找字符串中的下一个标记.

就是将一个字符串分割成一系列的子串.

②strtok函数的原型

char *strtok( char strToken, const char strDelimit ); 

strToken: 要分割的字符串.

strDelimite: 其中包含了一系列的分隔符.

③strtok函数的返回值

All of these functions return a pointer to the next token found in strToken. They return NULL when no more tokens are found. Each call modifies strToken by substituting a NULL character for each delimiter that is encountered.

所有这些函数都返回指向 strToken 中找到的下一个令牌的指针。当找不到更多令牌时,它们将返回 NULL

④细节说明

需要引用头文件 string.h

每次使用strtok函数都会将strToken中的分隔符替换成为 '\0'(字符串的结束标志).

二.strtok函数的具体使用

①PTA基础编程题目集---7-26 单词长度

②解决问题

#include<stdio.h>
#include<string.h>
int main()
{
    //使用strtok函数 
    //根据 map字符串中的内容,分割字符串str,返回值是分隔符后的字符的地址
    //strtok函数会把需要分割的字符赋值为 '\0'
    //char* strtok(char* str, const char* map);
    
    char str[1000] = { 0 };
    int i = 0;
    while (1)
    {
        scanf("%c", &str[i]);
        if (str[i] == '.')//输入'.'退出输入
            break;
        i++;
    }
    const char map[] = " .";//根据 map中的内容来分割字符串 str
    const char* ret = NULL;//接受首字符的地址
    int arr[1000] = { 0 };
    i = 0;
    //如果分割完毕,就返回空指针 NULL
    //从第二次分割开始,就不需要再传入起始地址了,strtok函数会自动记录分隔符后的字符的地址
    for (ret = strtok(str, map); ret != NULL; ret = strtok(NULL,map))
    {
        arr[i++] = strlen(ret);
    }
    //输出
    for (int j = 0; j < i; j++)
    {
        if (j == i - 1)
        {
            printf("%d", arr[j]);
            return 0;
        }
        printf("%d ",arr[j]);
    }
    return 0;
}

三.总结

1,strtok字符串分割函数是用来分割字符串的,会根据指定的内容来分割字符串,并将分隔符替换为'\0'(是会改变原来的字符串的,因此最好传入的是要分割的字符串的拷贝体),如果分割完毕,就会返回NULL空指针.

2,从第二次分割(第二次调用strtok函数)开始,就不需要再传入起始地址了,strtok函数会自动记录分隔符后的字符的地址.

相关推荐

  1. c语言字符串分割函数strtok_s和strtok

    2024-03-13 16:10:01       30 阅读
  2. 使用C语言strtok函数来分割字符串

    2024-03-13 16:10:01       39 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-13 16:10:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-13 16:10:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-13 16:10:01       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-13 16:10:01       20 阅读

热门阅读

  1. 安卓kotlin面试题 91-100

    2024-03-13 16:10:01       17 阅读
  2. 2024.03.12蓝桥云课笔记

    2024-03-13 16:10:01       20 阅读
  3. 【力扣二刷思路】DAY2

    2024-03-13 16:10:01       20 阅读
  4. Testing Library - About Queries

    2024-03-13 16:10:01       22 阅读
  5. js 判定一个string是否是正常的正则

    2024-03-13 16:10:01       20 阅读
  6. 面视题之——悲观锁和乐观锁

    2024-03-13 16:10:01       21 阅读