程序员考试补课笔记
程序员考试补课笔记-第六天
今天的整个课程只有这么的一道题,但是学到的东西确很多。下面给出这条题目:
字符数字转为整数数值(字符可以任意:比如"342A")遇到其它否数字取前数。
我所写的程序如下,自认为写得不错:
#define N 10;
int catio(const char *str) /*const 的作用是常数,所以这里的地址不会返回到实参里*/
{
int num[N];
int i=0;j=1,n=0;
for(;*str++;i++)
{
if(*str57)
break; /*判断是否数字数值*/
num=*str-48;
}
for(i-=1;i>=0;i--)
{
n+=num*j;
j*=10;
}
return n;
}
你们说是不是比较简单呢?现在看不出等看完以下的另一个程序先断定吧。如下:
long catio(char c[]);
{
int n,d;
char *q,*p;
long e=1,s=0;
for(q=p=c,n=0;*p!=’\0’ && *p>=’0’ && *p0)
{
d=*q++;
switch(d)
{
case 48: d=0;break; /*太长了,略*/
:
:
case 57: d=9;break;
}
s+=d*(e/=10);
n--;
}
return (s);
}
位律师回复
0条评论