zoukankan      html  css  js  c++  java
  • c++ 进制转换函数

    转自:https://blog.csdn.net/wangjunchengno2/article/details/78690248

    strtol 函数:

    它的功能是将一个任意1-36进制数转化为10进制数,返回是long int型。

    函数为long int strtol(const char *nptr, char **endptr, int base)

    base是要转化的数的进制,非法字符会赋值给endptr,nptr是要转化的字符,例如:

    char buffer[20]="10379cend$3";
    char *stop;
    printf("%d
    ",strtol(buffer, &stop, 8));
    printf("%s
    ", stop);

    输出结果:
    543
    9cend$3

    将一个8进制转化为10进制,读取1037,其他后面的为非法字符,转化结果以int型输出来。

    另外,如果base为0,且字符串不是以0x(或者0X)开头,则按十进制进行转化。如果base为0或者16,并且字符串以0x(或者0X)开头,那么,x(或者X)被忽略,字符串按16进制转化。如果base不等于0和16,并且字符串以0x(或者0X)开头,那么x被视为非法字符。

    最后,需要说明的是,对于nptr指向的字符串,其开头和结尾处的空格被忽视,字符串中间的空格被视为非法字符。

    c++中还有一些定向的转换:

    std::bitset(转2进制),std::oct(转8进制),std::dec (转10进制),std::hex(转16进制)。

    #include <bitset>
    #include <iostream>
    using namespace std;
    int main()
    {
        cout << "36的8进制:" << std::oct << 36 << endl;
        cout << "36的10进制" << std::dec << 36 << endl;
        cout << "36的16进制:" << std::hex << 36 << endl;
        cout << "36的2进制: " << bitset<8>(36) << endl;
        return 0;
    }
  • 相关阅读:
    win10 redis安装教程
    tomcat 最大并发连接数设置
    LeetCode 82 ——删除排序链表中的重复元素 II
    LeetCode 83 —— 删除排序链表中的重复元素
    LeetCode 61——旋转链表
    LeetCode 24——两两交换链表中的节点
    C++ 学习笔记之——文件操作和文件流
    LeetCode 4——两个排序数组中的中位数
    z 变换
    冲激串采样
  • 原文地址:https://www.cnblogs.com/KyleDeng/p/9262242.html
Copyright © 2011-2022 走看看