C语言关于exp的简单问题,每次都出错,谁来帮帮我
Input输入是多行,每行一个字符串s,至EOF结束。每个串s不超过10个字符,并且s转换后的整数不会超出int类型的表示范围。s的转换规则是:从第一个字符开始的前若干个...
Input
输入是多行,每行一个字符串s,至EOF结束。每个串s不超过10个字符,并且s转换后的整数不会超出int类型的表示范围。
s的转换规则是:从第一个字符开始的前若干个连续数字字符("0"~"9")转换为一个无符号的十进制整数,直到第一个非数字字符为止。从第一个非数字字符开始,都是非法字符。因此,如果一个串全部都是非法字符,那么它只能是0。
Output
输出为多行,与输入对应。每行输出是串s转换后的一个整数。
#include<stdio.h>
#include<string.h>
#include<math.h>
#define MAX_STR_LEN 21
int strToInt(char str[])
{
int n=0,i=0,j,s;
double v;
char a[20];
if(str==0) return -1;
else
{
s=0;
while(str[i]!=0&&str[i]>='0'&&str[i]<='9')
{
n++;
}
str[n]=0;
strcpy(a,str);
for(j=n;j>0;j--)
{
v=exp(10,j-1);
s+=(a[j]-48)*v;
}
return (int)s;
}
}
int main()
{
char s[MAX_STR_LEN];
while(gets(s) != NULL)
printf("%d\n", strToInt(s));
return 0;
} 展开
输入是多行,每行一个字符串s,至EOF结束。每个串s不超过10个字符,并且s转换后的整数不会超出int类型的表示范围。
s的转换规则是:从第一个字符开始的前若干个连续数字字符("0"~"9")转换为一个无符号的十进制整数,直到第一个非数字字符为止。从第一个非数字字符开始,都是非法字符。因此,如果一个串全部都是非法字符,那么它只能是0。
Output
输出为多行,与输入对应。每行输出是串s转换后的一个整数。
#include<stdio.h>
#include<string.h>
#include<math.h>
#define MAX_STR_LEN 21
int strToInt(char str[])
{
int n=0,i=0,j,s;
double v;
char a[20];
if(str==0) return -1;
else
{
s=0;
while(str[i]!=0&&str[i]>='0'&&str[i]<='9')
{
n++;
}
str[n]=0;
strcpy(a,str);
for(j=n;j>0;j--)
{
v=exp(10,j-1);
s+=(a[j]-48)*v;
}
return (int)s;
}
}
int main()
{
char s[MAX_STR_LEN];
while(gets(s) != NULL)
printf("%d\n", strToInt(s));
return 0;
} 展开
2个回答
展开全部
你这个程序应该是用pow(10, j)函数吧,是求10的j次方。
代码写的有点复杂,可以精简一下,且可以不用pow()函数!
#include<stdio.h>
#define MAX_STR_LEN 21
unsigned int strToInt(char str[])
{
unsigned int n=0;
int i;
for( i=0;str[i];i++ )
{
if ( str[i]>='0' && str[i] <= '9' )
n=n*10+str[i]-'0';
else
break;
}
return n;
}
int main()
{
char s[MAX_STR_LEN];
while(gets(s) != NULL)
printf("%d\n", strToInt(s));
return 0;
}
2014-12-12
展开全部
exp只有一个参数
如果你要求的是10的j-1次方,用pow
如果你要求的是10的j-1次方,用pow
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询