zoukankan      html  css  js  c++  java
  • HDOJ——2072单词数

    SSCANF用法:(继qsort,bsearch,strchr后发现的又一好使的函数)

    sscanf与scanf类似,都是用于输入的,只是后者以键盘(stdin)为输入源,前者以固定字符串为输入源。

    例子:

      1. 常见用法。

    char buf[512] ;

    sscanf("123456 ", "%s", buf);//此处buf是数组名,它的意思是将123456以%s的形式存入buf中!

    printf("%s ", buf);

    结果为:123456

    2. 取指定长度的字符串。如在下例中,取最大长度为4字节的字符串。

    sscanf("123456 ", "%4s", buf);

    printf("%s ", buf);

    结果为:1234

    3. 取到指定字符为止的字符串。如在下例中,取遇到空格为止字符串。

    sscanf("123456 abcdedf", "%[^ ]", buf);

    printf("%s ", buf);

    结果为:123456

    4. 取仅包含指定字符集的字符串。如在下例中,取仅包含1到9和小写字母的字符串。

    sscanf("123456abcdedfBCDEF", "%[1-9a-z]", buf);

    printf("%s ", buf);

    结果为:123456abcdedf

    当输入:

    sscanf("123456abcdedfBCDEF","%[1-9A-Z]",buf);

    printf("%s ",buf);

    结果为:123456

    5. 取到指定字符集为止的字符串。如在下例中,取遇到大写字母为止的字符串。

    sscanf("123456abcdedfBCDEF", "%[^A-Z]", buf);

    printf("%s ", buf);

    结果为:123456abcdedf

    6、给定一个字符串iios/12DDWDFF@122,获取 / 和 @ 之间的字符串,先将 "iios/"过滤掉,再将非'@'的一串内容送到buf中

    sscanf("iios/12DDWDFF@122", "%*[^/]/%[^@]", buf);

    printf("%s ", buf);

    结果为:12DDWDFF

    7、给定一个字符串“hello, world”,仅保留world。(注意:“,”之后有一空格)

    sscanf(“hello, world”, "%*s%s", buf);

    printf("%s ", buf);

    结果为:world

    %*s表示第一个匹配到的%s被过滤掉,即hello被过滤了

    如果没有空格则结果为NULL。

    代码如下:

    #include <stdio.h>
    #include <string.h>
    #include <math.h>
    char word[1000];
    char arr[100][100];  //arr用于存储以前出现过的单词
    int main()
    {
            int len, pos;
            char temp[100];
            while(gets(word) && strcmp(word, "#") != 0)//题目要求不是文章结尾为,注意strcmp用比较用“#”
            {
                    len = strlen(word);//总长度(包括空格)
                    pos = 0;
                    int cnt = 0;
                    // pos加单词长度一直到>len
                    while(pos <= len)
                    {
                            sscanf(word + pos, "%s", temp); //把一个单词存入temp,空格省去(sscanf应该是读到空格截止,对于sscanf,空格很重要)
                            //word + pos为指针指向位置
                            //printf("%s++++++++++++++++++++ ",temp);
                            int k;
                            for(k = 0; k < cnt; ++k)
                                    if(strcmp(temp, arr[k]) == 0)   //如果和以前存入的单词相同,则不计数
                                        break;
                            if(k == cnt)
                                    strcpy(arr[cnt++], temp);   //把temp存入arr,并计数器cnt加一
                            pos += strlen(temp) + 1;// +1表示加上空格,最后一次pos肯定会大于len
                    }
                    printf("%d ", cnt);
            }
            return 0;
    }

  • 相关阅读:
    软工2021个人阅读作业#2——构建之法和CI/CD的运用
    2021年.Net中级开发工程师面试题
    OneForAll框架搭建之旅:Vue + .NetCore WebApi(3)
    创建WebService服务--.NET Core与SoapCore 及遇到的问题(二)
    创建WebService服务--.NET Framework(一)
    面试小记
    Vue开发环境安装
    java笔记之设计模式 1、创建型模式:工厂方法
    Abp太重了?轻量化Abp框架
    Tomcat学习2:一键启动以及源码阅读
  • 原文地址:https://www.cnblogs.com/ghostTao/p/3856103.html
Copyright © 2011-2022 走看看