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;
}

原文地址:https://www.cnblogs.com/ghostTao/p/3856103.html