字符串中数字求和
2016-03-22 17:12
316 查看
给定一个字符串,计算字符串中数值的个数并求和。其中还包含了负号-,若紧跟负号的是一个数值,则表示这是一个负数,若后面跟着的不是数字,则不表示什么 输入:一个字符串 输出:数值个数 数值和 例子 输入:312ab-2-- -9--a 输出:3 301
#include<stdio.h>
#include <stdlib.h>
#include<math.h>
#include<string.h>
int strToint(char* str)
{
int sign,sum,k,i,len,num;
sign = 1;
sum = i = 0;
len = strlen(str);
if(str[i]=='-')
{
sign = -sign;
i++;
}
if(str[i]=='+')
{
i++;
}
num = 0;
for(;i<len;i++)
{
//sum += sum*int(pow(10,num))+(str[i]-'0');
sum = sum*10+(str[i]-'0');
//num++;
}
return sum*sign;
}
int main()
{
int i,len,j;
char str[1000001],tep[1000001],c;
double b = 0.9999;
int sum = 0;
gets(str);
len = strlen(str);
//i = atoi(str);
//b = atof(str);
//printf("%lf\n",b);
//sprintf(str,"%.3lf hello",b);
//puts(str);
j =0;
for(i=0;i<len;i++)
{
c = str[i];
if(str[i]=='-')
{
if(j>0)
{
sum+=strToint(tep);//atoi(tep);
memset(tep, 0, sizeof(tep));
}
j=0;
if(str[i+1]>='0'&&str[i+1]<='9')
{
tep[0]='-';
j++;
}
}
else
{
if(str[i]>='0'&&str[i]<='9')
{
tep[j] = str[i];
j++;
//if(i==len-1)
}
else
{
tep[j]='\0';
if(j>0)
{
sum+=strToint(tep);//atoi(tep);
memset(tep, 0, sizeof(tep));
j=0;
}
}
}
}
if(j>0)
{
sum+=strToint(tep);
}
printf("%d\n",sum);
return 0;
//312df-2ff--9
}
#include<stdio.h>
#include <stdlib.h>
#include<math.h>
#include<string.h>
int strToint(char* str)
{
int sign,sum,k,i,len,num;
sign = 1;
sum = i = 0;
len = strlen(str);
if(str[i]=='-')
{
sign = -sign;
i++;
}
if(str[i]=='+')
{
i++;
}
num = 0;
for(;i<len;i++)
{
//sum += sum*int(pow(10,num))+(str[i]-'0');
sum = sum*10+(str[i]-'0');
//num++;
}
return sum*sign;
}
int main()
{
int i,len,j;
char str[1000001],tep[1000001],c;
double b = 0.9999;
int sum = 0;
gets(str);
len = strlen(str);
//i = atoi(str);
//b = atof(str);
//printf("%lf\n",b);
//sprintf(str,"%.3lf hello",b);
//puts(str);
j =0;
for(i=0;i<len;i++)
{
c = str[i];
if(str[i]=='-')
{
if(j>0)
{
sum+=strToint(tep);//atoi(tep);
memset(tep, 0, sizeof(tep));
}
j=0;
if(str[i+1]>='0'&&str[i+1]<='9')
{
tep[0]='-';
j++;
}
}
else
{
if(str[i]>='0'&&str[i]<='9')
{
tep[j] = str[i];
j++;
//if(i==len-1)
}
else
{
tep[j]='\0';
if(j>0)
{
sum+=strToint(tep);//atoi(tep);
memset(tep, 0, sizeof(tep));
j=0;
}
}
}
}
if(j>0)
{
sum+=strToint(tep);
}
printf("%d\n",sum);
return 0;
//312df-2ff--9
}
相关文章推荐
- Linux下php安装Redis扩展
- zepto返回顶部动画
- 每天一个linux命令(60):scp命令
- Docker数据管理
- presto hbase
- Hibernate各种主键生成策略与配置详解
- HDU 1060:Leftmost Digit【数学】
- C++ Chapter 1. General(综述)
- 第二周项目4:穷举法解决组合问题
- R语言之导入数据源(一)
- 编译安装ckermit串口调试助手
- 部署开发常用工具
- 深入理解CSS定位中的堆叠z-index
- Linux下multipath多路径配置
- Redis 学习 ---- 8.对象
- ANDROID ASSET STUDIO
- 第一次接触Oracle存储过程
- 一款超炫3D旋转立方体动画特效
- 快速幂的初步学习
- Spring Security(12)——Remember-Me功能