http://poj.org/problem?id=1331
Time Limit: 1000MS | Memory Limit: 10000K |
Description
Input
Output
Sample Input
3 6 9 42 11 11 121 2 2 2
Sample Output
13 3 0
函数声明
long int strtol(const char *nptr,char **endptr,int base);
这个函数会将参数nptr字符串根据参数base来转换成长整型数。参数base范围从2至36,或0。参数base代表采用的进制方式,如base值为10则采用10进制,若base值为16则采用16进制等。当base值为0时则是采用10进制做转换,但遇到如’0x’前置字符则会使用16进制做转换、遇到’0’前置字符而不是’0x’的时候会使用8进制做转换。一开始strtol()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,再遇到非数字或字符串结束时('/0')结束转换,并将结果返回。若参数endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr返回。
strtol是atoi的增强版,主要体现在这几方面:
1.不仅可以识别十进制整数,还可以识别其它进制的整数,取决于base参数,比如strtol("0XDEADbeE~~", NULL, 16)返回0xdeadbee的值,strtol("0777~~", NULL, 8)返回0777的值。
2.endptr是一个传出参数,函数返回时指向后面未被识别的第一个字符。例如char *pos; strtol("123abc", &pos, 10);,strtol返回123,pos指向字符串中的字母a。如果字符串开头没有可识别的整数,例如char *pos; strtol("ABCabc", &pos, 10);,则strtol返回0,pos指向字符串开头,可以据此判断这种出错的情况,而这是atoi处理不了的。
3.如果字符串中的整数值超出long int的表示范围(上溢或下溢),则strtol返回它所能表示的最大(或最小)整数,并设置errno为ERANGE,例如strtol("0XDEADbeef~~", NULL, 16)返回0x7fffffff并设置errno为ERANGE
/* Author : yan * Question : POJ 1331 Multiply * Date && Time : Friday, February 11 2011 05:54 PM * Compiler : gcc (Ubuntu 4.4.3-4ubuntu5) 4.4.3 */ #include<stdio.h> char mul1[10],mul2[10],res[10]; int main() { //freopen("input","r",stdin); int n; int base; int m1,m2,m3; scanf("%d",&n); while(n--) { scanf("%s %s %s",mul1,mul2,res); base=2; while(base<17) { m1=strtol( mul1,'/0',base ); m2=strtol( mul2,'/0',base ); m3=strtol( res,'/0',base ); if(m1*m2==m3 && m1!=0 && m2!=0) { printf("%d/n",base); goto end; } base++; } if(base==17) printf("0/n"); end:; } return 0; }