将十六进制转换为十进制

时间:2012-06-14 10:24:36

标签: c++ algorithm hex decimal

我正在寻找一种方法将hex (十六进制)轻松转换为dec (十进制)。我发现了一种简单的方法:

int k = 0x265;
cout << k << endl;

但是我不能输入265。无论如何它是这样的:

输入:265

输出:613

有没有这样做?

注意:我试过了:

int k = 0x, b;
cin >> b;
cout << k + b << endl;

它不起作用。

8 个答案:

答案 0 :(得分:19)

#include <iostream>
#include <iomanip>

int main()
{
    int x, y;
    std::stringstream stream;

    std::cin >> x;
    stream << x;
    stream >> std::hex >> y;
    std::cout << y;

    return 0;
}

答案 1 :(得分:11)

使用std::hex操纵器:

#include <iostream>
#include <iomanip>

int main()
{
    int x;
    std::cin >> std::hex >> x;
    std::cout << x << std::endl;

    return 0;
}

答案 2 :(得分:5)

嗯,C方式可能就像......

#include <stdlib.h>
#include <stdio.h>

int main()
{
        int n;
        scanf("%d", &n);
        printf("%X", n);

        exit(0);
}

答案 3 :(得分:4)

这是一个使用字符串并使用ASCII表将其转换为十进制的解决方案:

#include <iostream>
#include <string>
#include "math.h"
using namespace std;
unsigned long hex2dec(string hex)
{
    unsigned long result = 0;
    for (int i=0; i<hex.length(); i++) {
        if (hex[i]>=48 && hex[i]<=57)
        {
            result += (hex[i]-48)*pow(16,hex.length()-i-1);
        } else if (hex[i]>=65 && hex[i]<=70) {
            result += (hex[i]-55)*pow(16,hex.length( )-i-1);
        } else if (hex[i]>=97 && hex[i]<=102) {
            result += (hex[i]-87)*pow(16,hex.length()-i-1);
        }
    }
    return result;
}

int main(int argc, const char * argv[]) {
    string hex_str;
    cin >> hex_str;
    cout << hex2dec(hex_str) << endl;
    return 0;
}

答案 4 :(得分:1)

    std::cout << "Enter decimal number: " ;
    std::cin >> input ;

    std::cout << "0x" << std::hex << input << '\n' ;

如果你添加一个可以是boolean或float或int的输入,它将在int main函数调用中传回...

使用函数模板,基于参数类型,C生成单独的函数以适当地处理每种类型的调用。所有函数模板定义都以关键字模板开头,后跟括在尖括号中的参数&lt;和&gt;。单个形式参数T用于要测试的数据类型。

考虑以下程序,其中要求用户输入整数然后浮点数,每个程序使用平方函数来确定平方。 使用函数模板,基于参数类型,C生成单独的函数以适当地处理每种类型的调用。所有函数模板定义都以关键字模板开头,后跟括在尖括号中的参数&lt;和&gt;。单个形式参数T用于要测试的数据类型。

考虑以下程序,要求用户输入一个整数,然后输入一个浮点数,每个程序都使用平方函数来确定平方。

#include <iostream>
 using namespace std;
template <class T>      // function template
T square(T);    /* returns a value of type T and accepts                  type T     (int or float or whatever) */
  void main()
{
int x, y;
float w, z;
cout << "Enter a integer:  ";
cin >> x;
y = square(x);
cout << "The square of that number is:  " << y << endl;
cout << "Enter a float:  ";
cin >> w;
z = square(w);
cout << "The square of that number is:  " << z << endl;
}

template <class T>      // function template
T square(T u) //accepts a parameter u of type T (int or float)
{
return u * u;
}

Here is the output:

Enter a integer:  5
The square of that number is:  25
Enter a float:  5.3
The square of that number is:  28.09

答案 5 :(得分:0)

我用这个:

template <typename T>
bool fromHex(const std::string& hexValue, T& result)
{
    std::stringstream ss;
    ss << std::hex << hexValue;
    ss >> result;

    return !ss.fail();
}

答案 6 :(得分:0)

这也应该工作。

#include <ctype.h>
#include <string.h>

template<typename T = unsigned int>
T Hex2Int(const char* const Hexstr, bool* Overflow)
{
    if (!Hexstr)
        return false;
    if (Overflow)
        *Overflow = false;

    auto between = [](char val, char c1, char c2) { return val >= c1 && val <= c2; };
    size_t len = strlen(Hexstr);
    T result = 0;

    for (size_t i = 0, offset = sizeof(T) << 3; i < len && (int)offset > 0; i++)
    {
        if (between(Hexstr[i], '0', '9'))
            result = result << 4 ^ Hexstr[i] - '0';
        else if (between(tolower(Hexstr[i]), 'a', 'f'))
            result = result << 4 ^ tolower(Hexstr[i]) - ('a' - 10); // Remove the decimal part;
        offset -= 4;
    }
    if (((len + ((len % 2) != 0)) << 2) > (sizeof(T) << 3) && Overflow)
        *Overflow = true;
    return result;
}

“溢出”参数是可选参数,因此您可以将其保留为NULL。

示例:

auto result = Hex2Int("C0ffee", NULL);
auto result2 = Hex2Int<long>("DeadC0ffe", NULL);

答案 7 :(得分:0)

仅用于:

cout << dec << 0x;