本文仅仅发布在CSDN我的博客:点击打开链接。
http://blog.csdn.net/pythontojava?viewmode=contents
转载请注明出处。
我用的IDE是VS2013.。代码在vc++6.0不能编译,要把int _tmain(int argc, _TCHAR* argv[]) 改成 int main() 。
一个以字符串形式存储的正float数字,写程序把数字提取出来,转换成float型数字。注意字符串里只能有一个小数点,且小数点不能在第一位,且数字相邻。
比如字符串s="abc202.34de",取出202.34。
字符串s1="1.2.3",程序失效,返回0。
字符串s2=".333",程序失效,返回0。
// string_find_float.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include<iostream>
#include<string>
using namespace std;
float to_float(string s)
{
int i = 0,n=0;
int point_index = s.find('.');
float result= 0,under_0=0;//under_0存储小数部分
if (count(s.begin(), s.end(), '.')>1)
{
return 0;//字符串里只能有1个或0个小数点,不然出错退出
}
if (s.find('.') != -1)//字符串里有小数点
{
if (point_index >= 1 && point_index<s.size()-1)//小数点位置合理,不能在字符串第1位,且不能在最后一位
{
for (i = 0; i <= point_index - 1; i++)//计算整数部分
{
if (s[i] >= '0'&&s[i] <= '9')
{
result = result * 10 + s[i] - 48;
}
}
for (i = s.size() - 1; i >= point_index-1 ; i--)//计算小数部分
{
if (s[i] >= '0'&&s[i] <= '9')
{
if (i == point_index-1)
{
under_0 = under_0 * 0.1 + 0;//i=小数点前一位,under_0+0
}
else
{
under_0 = under_0* 0.1 + s[i] - 48;
}
}
}
result = result + under_0;//把整数部分和小数部分相加
}
}
else//字符串只有整数部分
{
for (i = 0; i <= s.size() - 1;i++)
{
if (s[i] >= '0'&&s[i] <= '9')
{
result= result * 10 + s[i] - 48;
}
}
}
return result;
}
int _tmain(int argc, _TCHAR* argv[])
{
string s = "abc202.34de";
cout<<to_float(s)<<endl;
system("pause");
return 0;
}
运行结果
4