资料引自: 传送门

sscanf函数原型:

Int sscanf( const char * src, const char * format, ...);
int scanf( const char * format, ...);
这两个函数很相似,只是第一个函数以src(固定字符串)作为输入,而第二个函数以标准输入stdin读取输入;其中的format是格式控制字符串,它包含控制字符(如:%d,%i,%s等),空白字符(如:空格、制表符\t、回车换行符\n 或其连续组合)以及非空白字符;"..."是一组指针变量,是上述函数用来保存结果值的;返回值为被成功赋值的指针变量的个数,如果该函数发生错误,则返回EOF(-1)。

格式控制format:

format可以是一个或多个 {%[*] [width] [{h | l | I64 | L}]type | 空白字符| 非空白符号}
该公式中符号解释如下:
  • {a|b|c}:表示a,b,c中选一或几个;
  • [d]:表示可以有d也可以没有d;
  • "*" :亦可用于格式中, (即 %*d 和 %*s) 加了星号 (*) 表示跳过此数据不读入. (也就是不把此数据读入参数中) ,用法如:
const char sourceStr[] = "hello, world";
char buf[10] = ;
sscanf(sourceStr, "%*s%s", buf); //%*s表示第一个匹配到的%s被过滤掉,即hello被过滤了
cout << buf<< endl;
结果为:world  
  • width:宽度:一般可以忽略,用法如:
const char sourceStr[] = "hello, world";  

char buf[10] = ;  

sscanf(sourceStr, "%5s", buf); //%5s,只取5个字符  

cout << buf<< endl;  
  • {h | l | I64 | L}:参数的size,通常h表示单字节size,I表示2字节 size,L表示4字节size(double例外),l64表示8字节size;
  • type:即为控制字符如:d, i, f, s, p, 及集合[ ],(注意%号写在了最前面了,这里不能再加一个%号了。) 需特别注意和说明的控制符是集合%[ ]:
%[a-z] 表示匹配a到z中任意字符,贪婪性(尽可能多的匹配)
%[aB'] 匹配a、B、'中一员,贪婪性
%[^a] 匹配非a的任意字符,贪婪性  

例如取遇到空格为止字符串:

sscanf("123456 abcdedf", "%[^ ]", buf);
printf("%s\n", buf);
结果为:123456  

再如:

const char* s = "iios/12DDWDFF@122";
char buf[20];
sscanf( s, "%*[^/]/%[^@]", buf );
结果为:12DDWDFF
先将 "iios/"过滤掉,再将到字符<a href="mailto:'@'">'@'</a>为止的一串12DDWDFF 
  • 空白字符:' ', '\n', '\t' 等;非空白字符:即一般字符。
    格式匹配过程:

    该函数从源(src 或stdin)的前面顺序读取一个或一段字符,并将其与顺序取自格式控制字符串中的字符或字符串进行比较匹配:
    当遇到一个空白字符时,则不比较而跳过(空格呢?);当遇到一个非空白字符时,进行比较但不存进指针变量内;当遇到控制字符时,如果能匹配上,则按照控制字符的意义将从源读取的字符或字符串存入到下一个指针指向地址处;

    特别注意的是:

    如果控制字符里有width,则会将最多这么多字符串存进下一个指针指向的地址处;如果是控制符%[],则将源中字符串自当前位置开始到第一个不符合该控制符规定的匹配字符的所有字符存储到下一个指针指向的地址处。

常见例子:

1. 常见用法。

char buf[512] ;
sscanf("123456 ", "%s", buf);//此处buf是数组名,它的意思是将123456以%s的形式存入buf中!
printf("%s\n", buf);
结果为:123456

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

sscanf("123456 ", "%4s", buf);
printf("%s\n", buf);
结果为:1234

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

sscanf("123456 abcdedf", "%[^ ]", buf);
printf("%s\n", buf);
结果为:123456

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

sscanf("123456abcdedfBCDEF", "%[1-9a-z]", buf);
printf("%s\n", buf);
结果为:123456abcdedf

当输入:

sscanf("123456abcdedfBCDEF","%[1-9A-Z]",buf);
printf("%s\n",buf);
结果为:123456

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

sscanf("123456abcdedfBCDEF", "%[^A-Z]", buf);
printf("%s\n", buf);
结果为:123456abcdedf

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。

8.处理2006:03:18 - 2006:04:18(‘-’两边有空格)和2006:03:18-2006:04:18(‘-’两边无空格):

前者:

char sztime1[16] = "", sztime2[16] = "";
sscanf("2006:03:18 - 2006:04:18", "%s - %s", sztime1, sztime2);

后者:

char sztime1[16] = "", sztime2[16] = "";
sscanf("2006:03:18 - 2006:04:18", "%[0-9,:]-%[0-9,:]", sztime1, sztime2);

实例:

题目描述

不知道大家有没有了解过 ACM 竞赛,这里简单介绍下排名的规则。每题都有一个类似于“提交次数/完成时间”的完成情况:“-/--” 表示没有提交过此题, “8/--” 表示这题提交了 8 次, 但是没 AC, “8/135”表示这题提交了 8 次,在第 135 分钟第 8 次提交 AC 了。罚时的计算,如果没 AC 就没罚时,否则这题的罚时就是(提交次数-1)*每次错误提交的罚时 P+完成耗时。比如 “8/135” 的数据, 如果每错误提交一次罚时 20 分钟的话, 罚时就是 (8-1)*20+135=275。总罚时为所有题目的罚时相加。现在 TonyY手上就有一场比赛数据, 一共有 5 道题, 现在他想生成个排名表,你可以帮助他吗?

输入

输入数据第一行为两个整数 N,P(1

输出

输出数据共 N 行,为排序后的结果,包括名字,做题数和总罚时。排名显然先按 AC 题数的多少排,多的在前,题数相同再按总罚时的多少排,少的在前,如果凑巧前两者都相等,则按名字的字典序排,小的在前。

输入示例

3 20
Alice -/-- 1/1 1/2 1/3 1/4
TonyY 1/3 2/12 1/32 2/140
1/39
William 1/50 1/67 6/90 8/150
1/35

输出示例

TonyY 5 266
William 5 632
Alice 4 10

思路

使用sscanf()函数分离出字符串的整数

#include<iostream>
#include<algorithm>
#include<string>
#include<cstdio>
using namespace std;

struct Races{
    string name;
    int TimeSum;
    int ProCnt;
}acm[1005];
bool cmp(struct Races m,struct Races n)
{
    if (m.ProCnt == n.ProCnt)
    {
        if (m.TimeSum == n.TimeSum)
        {
            return m.name < n.name;
        }
        else
        {
            return m.TimeSum < n.TimeSum;
        }
    }
    else
    {
        return m.ProCnt > n.ProCnt;
    }
}
int main()
{
    int N,P,i,j,k,x,y;
    char TmpName[15];

    cin >> N >> P;

    for (i = 0;i < N;i++)
    {
        cin >> acm[i].name;

        acm[i].ProCnt = 0;
        acm[i].TimeSum = 0;
        for (j = 0;j < 5;j++)
        {
            scanf("%s",TmpName);

            if (TmpName[0] != '-')
            {
                for (k = 1;k < 10;k++)
                {
                    if (TmpName[k] == '/')
                    break;
                }
                if (TmpName[k + 1] != '-')
                {
                    acm[i].ProCnt++;
                    sscanf(TmpName,"%d/%d",&x,&y);
                    acm[i].TimeSum += ((x - 1) * P + y);
                }
            }
        }
    }

    sort(acm,acm + N,cmp);

    for (i = 0;i < N;i++)
    {
        cout << acm[i].name << " " << acm[i].ProCnt << " " << acm[i].TimeSum << endl;
    }

    return 0;
}

sscanf()函数的使用及其实例的更多相关文章

  1. c语言 sscanf()函数

    sscanf()函数用于从字符串中读取指定格式的数据,其原型如下:    int sscanf (char *str, char * format [, argument, ...]); [参数]参数 ...

  2. sscanf函数详解 & 查找文件字符串

    1. sscanf函数 sscanf() - 从一个字符串中读进与指定格式相符的数据. 1.1 函数原型 int scanf(const char *format, ...); int fscanf( ...

  3. [转载]sscanf函数

    来源:http://c.biancheng.net/cpp/html/296.html 头文件:#include <stdio.h> sscanf()函数用于从字符串中读取指定格式的数据, ...

  4. PHP sscanf() 函数

    实例 Parse a string: <?php高佣联盟 www.cgewang.com$str = "age:30 weight:60kg";sscanf($str,&qu ...

  5. sscanf函数

    sscanf函数用法举例 #include <stdio.h> #include <string.h> #define N 512 int main() { char buf[ ...

  6. sscanf函数和正则表达式

    看了几篇介绍sscanf函数,真是发现自己好多东西没理解透,详细介绍使用在sscanf中使用正则表达式. 第一篇: 此文所有的实验都是基于下面的程序: char str[10]; for (int i ...

  7. C语言sprintf与sscanf函数[总结]

    sprintf函数 sprintf函数原型为 int sprintf(char *str, const char *format, ...).作用是格式化字符串,具体功能如下所示: (1)将数字变量转 ...

  8. sscanf 函数

    sscanf 函数: 从一个字符串中读进与指定格式相符的数据. 头文件: #include<stdio.h> 返回值:  sscanf("1 2 3","%d ...

  9. php sscanf() 函数使用

    定义和用法 sscanf() 函数根据指定的格式解析来自一个字符串的输入. 如果只向该函数传递两个参数,数据将以数组的形式返回.否则,如果传递了额外的参数,那么被解析的数据会存储在这些参数中.如果区分 ...

随机推荐

  1. 谱多流形聚类SMMC

    今天是2015年的最后一天,决定尽量乘着这三天休息把毕设主题的博客给更完,今天写smmc的算法,接下来三天会对前面的三个算法kmeans.SC以及smmc应用在今年的研究生建模提供的数据中进行matl ...

  2. 排序图解:js排序算法实现

    之前写过js实现数组去重, 今天继续研究数组: 排序算法实现. 排序是数据结构主要内容,并不限于语言主要在于思想:大学曾经用C语言研究过一段时间的排序实现, 这段时间有空用JS再将排序知识点熟悉一遍. ...

  3. C# 7.0 新特性4: 返回引用

    本文参考Roslyn项目中的Issue:#118. 1. C# 7.0 新特性1: 基于Tuple的“多”返回值方法 2. C# 7.0 新特性2: 本地方法 3. C# 7.0 新特性3: 模式匹配 ...

  4. versionCompare 版本号比较工具

    简介 需求非常简单,需要比较软件或app的版本号,判断大小,形如 0.10.2形式的版本号字符串.实现逻辑是按照点(.)分割字符串,然后逐级比较版本大小.不存在的按0处理,空字符串小于非空字符串. 测 ...

  5. sockaddr与sockaddr_in结构体简介

    struct sockaddr { unsigned  short  sa_family;     /* address family, AF_xxx */char  sa_data[14];     ...

  6. 删除root子目录,如何恢复子目录配置文件

    手贱,一不小心rm -rf 问题描述:删除/root/子目录文件(含隐藏配置文件)shell变成-bash-4.2#,如何恢复原貌 解决方法: root用户进入,自己配置相关文件:mkdir /roo ...

  7. Collection中list集合的应用常见的方法

    集合 : 用存放对象的容器(集合)     Collection : 跟接口 : 单列集合          ---> List :有序的 ,元素是可以重复的.          ---> ...

  8. jQuery自定义插件

    jQuery自定义插件 jQuery自定义插件按照功能分类,可以分为三类, 1>封装对象方法的插件,(也就是基于某个DOM元素的jQuery对象,局部的) 2>封装全局函数的插件,   ( ...

  9. this Activity.this Activity.class

    1. this 与 Activity.this this是你当前对象的引用,在你的例子中你肯定在内部类ClickEvent里面实现intent,他指向的是ClickEvent,而不是你要传入的Acti ...

  10. zabbix的配置使用

    1 zabbix忘记密码的解决办法 zabbix的默认密码我们都知道是admin,zabbix都是存在与数据库中的 select * from zabbix.user where alias='adm ...