sscanf用法

sscanf用法SSCANF 用法 继 qsort bsearch strchr 后发现的又一好使的函数 sscanf 与 scanf 类似 都是用于输入的 只是后者以键盘 stdin 为输入源 前者以固定字符串为输入源 例子 nbsp 1 常见用法 charbuf 512 sscanf s buf 此处 buf 是数组名 它的意思是将 123

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

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

例子:

  1. 常见用法。


char buf[512] ;


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


printf(“%s\n”, buf);


结果为:


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


sscanf(” “, “%4s”, buf);


printf(“%s\n”, buf);


结果为:1234


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


sscanf(” abcdedf”, “%[^ ]”, buf);


printf(“%s\n”, buf);


结果为:


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


sscanf(“abcdedfBCDEF”, “%[1-9a-z]”, buf);


printf(“%s\n”, buf);


结果为:abcdedf


当输入:


sscanf(“abcdedfBCDEF”,”%[1-9A-Z]”,buf);


printf(“%s\n”,buf);


结果为:


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


sscanf(“abcdedfBCDEF”, “%[^A-Z]”, buf);


printf(“%s\n”, buf);


结果为:abcdedf


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


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


printf(“%s\n”, buf);


结果为:12DDWDFF


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


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


printf(“%s\n”, buf);


结果为:world


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


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

代码如下:

#include


#include


#include


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++++++++++++++++++++\n”,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\n”, cnt);
        }
        return 0;
}



































 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/229240.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月16日 下午5:08
下一篇 2026年3月16日 下午5:09


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号