zoukankan      html  css  js  c++  java
  • 关于sscanf()处理字符串的总结

     

    首先应该注意的是 sscanf()只能对字符数组进行操作,但是不能对string字符串操作

     

    (1)最简单的其实是默认的用法,比如

    sscanf(ch,"%s%s",a,b); 其中a,b为字符数组,最简单的分割方式

    (2)分割含有整数的时候比较简单也很好用:

    基本用法:

     scanf("%d+%d",&a,&b);

    sscanf(c,"%d+%d=%d",&m,&n,&p)直接这样用就行

    (2)下面的一种是遇到特定的字符(暂时scanf()还不知道怎么实现该作用)

    #include <iostream>
    #include <cstdio>
    #include <string>
    #include <cstring>
    using namespace std;
    int main(){
     char  a[20]="" ,b[20]="" ;
     char ch[100];
     while(1){
     cin.getline(ch,100);
     //scanf("%s+%s",a,b);
        sscanf(ch,"%s + %s",a,b);//如果是两个字符串的话,并且输入的时候必须是... + ...
                                  //如果没有空格的话就换到另一数组的话,只能是下面的这种方式
    // sscanf(ch,"%[a-z]+%[a-z]",a,b);
     cout<<"**********"<<a<<"************"<<b<<"**********";
     }
     return 0;
    }
    


     

    参考:

    int a, b, c;
      sscanf("2006:03:18", "%d:%d:%d", a, b, c);
      以及2006:03:18 - 2006:04:18:
      char sztime1[16] = "", sztime2[16] = "";
      sscanf("2006:03:18 - 2006:04:18", "%s - %s", sztime1, sztime2); (此种用法结合网址:)
      但是后来,我需要处理2006:03:18-2006:04:18
      仅仅是取消了‘-’两边的空格,却打破了%s对字符串的界定。
      我需要重新设计一个函数来处理这样的情况?这并不复杂,但是,为了使所有的代码都有统一的风格,我需要改动很多地方,把已有的sscanf替换成我自己的分割函数。我以为我肯定需要这样做,并伴随着对sscanf的强烈不满而入睡;一觉醒来,发现其实不必。
      format-type中有%[]这样的type field。如果读取的字符串,不是以空格来分隔的话,就可以使用%[]。
      %[]类似于一个正则表达式。[a-z]表示读取a-z的所有字符,[^a-z]表示读取除a-z以外的所有字符。
      所以那个问题也就迎刃而解了:
      sscanf("2006:03:18 - 2006:04:18", "%[0-9,:] - %[0-9,:]", sztime1, sztime2)

    参考网址:

  • 相关阅读:
    最小生成树(Prim和Kruscal)
    SPFA(还是稍微写写吧,虽然没什么用)
    最短路径(随便写写)(Floyd,Bellman-Ford,Dijkstra)
    Just a Hook HDU
    数论逆元
    最长上升子序列(LIS)算法(附Codeforces Round #641 (Div. 2),B题题解)
    Educational Codeforces Round 86 (Rated for Div. 2)
    Codeforces Round #633 (Div. 2)
    Codeforces Round #631 (Div. 2)
    Mayor's posters(线段树离散化)
  • 原文地址:https://www.cnblogs.com/zswbky/p/5432039.html
Copyright © 2011-2022 走看看