zoukankan      html  css  js  c++  java
  • POJ1331 Multiply(strtol函数练习)

    题目链接:http://poj.org/problem?id=1331

    主要介绍strtol函数:

    long int strtol(const char *nptr,char **endptr,int base);
    
    strtol函数会将参数nptr字符串根据参数base来转换成长整型数。
    
    
    参数base范围从2至36,或0。参数base代表采用的进制方式,如base值为10则采用10进制,若base值为16则采用16进制等。
    当base值为0时则是采用10进制做转换,但遇到如’0x’前置字符则会使用16进制做转换、遇到’0’前置字符而不是’0x’的时候会使用8进制做转换。 一开始strtol()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,再遇到非数字或字符串结束时('')结束转换,
    并将结果返回。若参数endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr返回;若参数endptr为NULL,则会不返回非法字符串。 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

      

    #include<string>
    #include<iostream>
    #include<cstdio>
    #include<cstdlib>
    #include<cstring>
    using namespace std;
    int  main()
    {
        int t;
        cin>>t;
    
        char a[100],b[100],c[100];
        while(t--){
                int base=0;
                scanf("%s%s%s",a,b,c);
        //cin>>b>>c;
        for(int i=2;i<=16;i++)
        { int ta,tb,tc;
        ta=strtol(a,NULL,i);
        if(!ta&&a!="0")continue;
    
        tb=strtol(b,NULL,i);
        if(!tb&&b!="0")continue;
    
        tc=strtol(c,NULL,i);
        if(!tc&&c!="0")continue;
    
        if(ta*tb==tc)
        {
    
            base =i;break;
        }
    
    
    
        }
        cout<<base<<endl;
        }
    
    
        return 0;
    }
    

      

  • 相关阅读:
    面试题总结
    软件测试面试心得
    git上传本地文件到gitee上
    一个测试员失业的自述
    整理了Linux常用命令变量
    java B2B2C多用户商城系统-搜索分词架构分享
    B2B2C商城系统-Table组件封装代码分享
    Javashop 电商系统sso登录实现
    b2b2c商城系统-会员预存款架构及源码分享
    java 商城系统源码分享-snowflake发号器
  • 原文地址:https://www.cnblogs.com/jin-nuo/p/5439407.html
Copyright © 2011-2022 走看看