str2num

原创 2012年03月29日 15:13:57
// str2num.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"
#include "math.h"
int str2num(char *s)
{
	char ch;
	int i=0;
	int a[255];
	int sum=0;
	do
	{
		ch=s[i];
		a[i]=ch-'0';
		i++;		
	}while(ch!='\0');
	i-=2;
	for (int j=0;j<i;j++)
	{
		//sum+=a[j]*pow(10,i-j);
		sum+=a[j];
		sum*=10;
	}
	sum+=a[j];//j=i

	return sum;
}
float  str2numf(char *s);

int main(int argc, char* argv[])
{
	printf("Hello World!\n%d\n%d\n%f\n", str2num("12345"),str2num("0"),str2numf("123.678"));
	printf("%f\n%f\n%f\n", str2numf("12345"),str2numf("123678."), str2numf("0.12345"));
	printf("%f\n", str2numf(".12345"));
	return 0;
}

float  str2numf(char *s)
{
	char ch;
	int i=0;
	int a[255];//整数部分
	int k=0;
	int b[255];//小数部分
	float sum=0.0f;
	bool zhengshu=true;
	do
	{
		ch=*s;
		if (ch!='\0')
		{
			s++;
		} 
		else
		{
			break;
		}
		if (ch=='.')
		{
			zhengshu=false;
			continue;
		} 

		if (zhengshu)
		{
			a[i]=ch-'0';
			i++;
		} 
		else
		{
			b[k]=ch-'0';
			k++;
		}
		
	}while(1);

	for (int j=0;j<=i-1;j++)
	{
		//sum+=a[j]*pow(10,i-j);
		if (j==i-1)
		{
			sum+=a[i-1];
		}
		else
		{
			sum+=a[j];
			sum*=10;
		}

	}


	float xiaoshu=0.0f;
	for (j=k-1;j>=0;j--)
	{
		xiaoshu+=b[j];
		xiaoshu/=10.0f;
	}
	sum+=xiaoshu;
	return sum;
}

相关文章推荐

Cpp--string常用函数用法总结

标准c++中string类函数介绍 注意不是CString 之所以抛弃char*的字符串而选用C++标准程序库中的string类,是因为他和前者比较起来,不必 担心内存是否足够、字符串长度等等...

C语言实现的 itoa(int num, str *temp, int radix) 与 atoi(str *temp)

/* * file name : my_itoa.c * function : achieve itoa and atoi * date : 2012-5-3 * modify ...

ASCII2NUM 3.0

  • 2012年06月29日 14:13
  • 98KB
  • 下载

Goat in the Garden 2&&http://acm.timus.ru/problem.aspx?space=1&num=1348

题意:给你一个山羊,问你山羊能吃到草需要拉伸的最小距离,和山羊能吃完草所要拉伸的最小距离 思路:首先求一点到一条线段距离要考虑垂线是否落在线段上,如果落在线段上,利用海伦公式求出高h即可,如果不在则...

Leetcode_num2_Maximum Depth of Binary Tree

题目: Given a binary tree, find its maximum depth. The maximum depth is the number of nodes along t...

function num_lines = specobjid2deg(specobjid_filepath, deg_filepath, len_format

function num_lines = specobjid2deg(specobjid_filepath, deg_filepath, len_format) %Author: shizhixin ...

LeetCode Num74_Search a 2D Matrix

问题描述:   Write an efficient algorithm that searches for a value in an m x n matrix. This mat...

MINIGUI-STR(FOR UCOS2)

  • 2011年01月23日 11:30
  • 9.55MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:str2num
举报原因:
原因补充:

(最多只允许输入30个字)