C++ 十进制转换为十六进制 ,十进制转换为二进制,十六进制转换为十进制

本文深入讲解了十进制与十六进制、二进制之间的转换方法,提供了详细的C++代码实现,包括除k取余法和乘以基数法,适用于理解和实现不同进制间的数值转换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

十进制转换为十六进制,也就是 采用 除k取余法 ,直接让10处以16,再对 数据如果小于10和大于10进行处理,代码如下:

 

#include<iostream>
#include<string>
using namespace std;
int main()
{
	long a;//输入的数
	int y=0;//循环中的余数
	string s="";//输出的结果
	cin>>a;
	if(a==0)//0比较特殊,单独处理
	{
	cout<<0;
	return 0;
	}
 
	while(a>0)//大于0的数
	{
		y=a%16;  //求余
		if(y<10)   //小于10的余数
		s=char('0'+y)+s;  //利用字符的ascll码在字符串前面拼接
		else
		s=char('A'-10+y)+s;  //大于9的余数用ABCDE表示
		a=a/16;   
	}
	cout<<s;
	return 0;
}

 

十六进制转换为10进制,采取的是 乘以16

#include<iostream>  
#include<string>  
#include<math.h>  
using namespace std;  
  
int main()  
{  
    string s;  
    int i=0,count,sum;  
    while(getline(cin,s))  
    {  
        int count=s.length();  
        sum=0;  
        for(i=count-1;i>=0;i--)//从十六进制个位开始,每位都转换成十进制  
        {  
            if(s[i]>='0'&&s[i]<='9')//数字字符的转换  
            {  
                sum+=(s[i]-48)*pow(16,count-i-1);  
            }  
            else if(s[i]>='A'&&s[i]<='F')//字母字符的转换  
            {  
                sum+=(s[i]-55)*pow(16,count-i-1);  
            }  
        }  
        cout<<sum;  
    }  
}  

 

十进制 转换为 二进制,采取的是 除2取余法,其中把 2 换成其他小于10的数,可以变成相应的 其他进制

 

#include<iostream>

using namespace std;

int main(){
	int a;
	cin>>a;
	int result=0;
	int temp=a;
	int j=1;
	while(temp){
		result=result+j*(temp%2);
		temp=temp/2;
		j=j*10;
	}
	
	cout<<result<<endl;
	
	
	return 0;
} 

 

二进制转换十进制是计算机科学中常见的转换操作。在C++中,可以通过位运算和数学方法将二进制字符串转换为对应的十进制数。下面是一个简单的例子,展示如何将二进制字符串转换十进制: ```cpp #include <iostream> #include <string> #include <cmath> int binaryToDecimal(const std::string &binary) { int decimal = 0; int base = 1; // 2的0次方 // 从字符串的最后一个字符开始向前遍历 for (int i = binary.length() - 1; i >= 0; --i) { // 当前位是1,则加上当前的权值 if (binary[i] == '1') { decimal += base; } // 权值翻倍,因为是二进制 base *= 2; } return decimal; } int main() { std::string binary; std::cout << "请输入一个二进制数: "; std::cin >> binary; int decimal = binaryToDecimal(binary); std::cout << "二进制数 " << binary << " 对应的十进制数是 " << decimal << std::endl; return 0; } ``` 在这个例子中,我们定义了一个`binaryToDecimal`函数,它接受一个二进制字符串作为参数,并返回对应的十进制数。在`main`函数中,我们从用户那里获取二进制字符串,然后调用`binaryToDecimal`函数,并输出结果。 这段代码的核心思想是遍历二进制字符串中的每一个字符,检查它是否是'1',如果是,则将当前位置的二进制权值加到十进制结果中。权值是以2的幂为基础,从字符串的最后一个字符(即最低位)开始,向左每移动一位,权值翻倍。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值