算法入门经典中提到一种函数sscanf()用法如下:
#include<iostream>
#include<stdio.h>
using namespace std;
int main()
{
char a[100];
while(cin>>a)
{
int v;
sscanf(&a[0],"%d",&v);
cout<<a<<endl;
cout<<v<<endl;
}
return 0;
}
其中有点好玩的就是sscanf函数第一个参数必须是带下标的,也就是说这里的a[0]并不是常理上理解的单个字符a[0],而是一个“指向a字符数组中从下标0开始到\0结束的字符串“的指针。当把下标去掉是不能通过编译的。而这句代码的功能是,如果字符串的前几个字符是数字,(注意这是前提),那么他就可以去掉后面的非数字字符。提取出数字到int型变量v里面。
例如:输入111asdf会得到v= 111
但是不能输入类似sdf111lsfkj之类的东东。
<pre name="code" class="cpp">#include<iostream>
#include<stdio.h>
using namespace std;
int main()
{
char a[100];
while(cin>>a)
{
char str[512]={0};
sscanf("123456","%s",str);
printf("str=%s\n",str);
//2.取指定长度的字符串。如在下例中,取最大长度为4字节的字符串
sscanf("123456","%4s",str);
printf("str=%s\n",str);
//3. 取到指定字符为止的字符串
sscanf("123456abcdedf","%[^c]",str);
printf("str=%s\n",str);
//4. 取仅包含指定字符集的字符串。如在下例中,取仅包含1到9和小写字母的字符串
//%[a-z] 表示匹配a到z中任意字符,贪婪性(尽可能多的匹配
sscanf("123456abcdedfBCDEF","%[1-9a-z]",str);
printf("str=%s\n",str);
<span style="white-space:pre"> </span>//5. 取到指定字符集为止的字符串。如在下例中,取遇到大写字母为止的字符串
<span style="white-space:pre"> </span>//%[^A-Z] 匹配非A-Z的任意字符,并且停止读入,贪婪性
<span style="white-space:pre"> </span>sscanf("123456abcdedfBCDEF","%[^A-Z]",str);
<span style="white-space:pre"> </span>printf("str=%s\n",str);
}
return 0;
}