C++提取字符串里面的数字

现有一串字符串,如下:“chr4,+77311909,25M,1;chr2,+63439874,25M,1;chr10,-58952431,25M,1;chrX,-120369984,25M,1;chr13,-58752466,25M,1;chrX,-126676818,25M,1;”
现在要做的是提取字符串中所有的+号和-号后面的数字,比如提取+号后面的77311909,-号后面的58952431,怎么样编写算法提取,谢谢。

#include <iostream>
#include <string>
using namespace std;
int main()
{
string s = "chr4,+77311909,25M,1;chr2,+63439874,25M,1;chr10,-58952431,25M,1;chrX,-120369984,25M,1;chr13,-58752466,25M,1;chrX,-126676818,25M,1;";
int value = 0;
int i = 0;
int sign = 0;
while(i<s.length())
{
while(i<s.length() && s[i]!='+' && s[i]!='-')//先找到开头的+或-
{
i++;
}
if(i>=s.length())
break;
if(s[i]=='+')//确定正负号
sign = 1;
if(s[i]=='-')//确定正负号
sign = -1;
i++;
value = 0;
while(i<s.length() && s[i]!=',')//开始累加,遇到逗号停止累加
{
value = value * 10 + s[i] - '0';
i++;
}
cout << value*sign << endl;
}
return 0;
}

温馨提示:答案为网友推荐,仅供参考
第1个回答  2014-02-12
# include <iostream>
# include <string>

const int LEN = 99;

void pick(std::string str);

int main (void)
{
using namespace std;

string str = "chr4,+77311909,25M,1;chr2,+63439874,25M,1;chr10,-58952431,25M,1;chrX,-120369984,25M,1;chr13,-58752466,25M,1;chrX,-126676818,25M,1;";

pick(str);

return 0;
}

void pick(std::string str)
{
char pick[6][LEN];

int num, goal;

num = goal = 0;

while(str[goal])
{
if('+' == str[goal] || '-' == str[goal])
{
int i = 0;

goal++;

while(',' != str[goal])
{
pick[num][i] = str[goal];

i++;

goal++;
}

pick[num][i] = '\0';

num++;
}

goal++;
}

for(int i = 0; i < 6; ++i)
{
std::cout << pick[i] << std::endl;
}
}

这样应该可以

追问

可能不够具有通用性,如果在不知道字符串有多少个+号或者-号的时候,你这个算法就可能不适用了。不过很感谢。

第2个回答  2014-02-12
纯c加上string.h的库函数的话,
如果格式都是这样的,建议用strtoken把这个字符串用分号打开。
然后再用strtoken打散逗号,然后放在数据结构里。
就可以完成提取了。追问

这个方法挺麻烦,有没有更好的方法?

追答

或可以考虑c++中正则表达式做这个事情,也可以,但是要涉及学习正则表达式的成本。

追问

谢谢

第3个回答  2014-02-12
提取出来还是放在字符串里么
string a,ans;

cin>>a;
for (int q=0;q<a.length();q++)
if (a[q]>='0'&&a[q]<='9')
ans+=a[q];
cout<<a[q];
相似回答