简单的进制转换函数

本文介绍了一个通用的进制转换函数,并展示了其在不同进制转换中的应用,包括从10进制到40进制及二进制的转换。

最近有个项目用到各种进制之间的转换,比如10进制转40进制,转二进制等。

于是写了一个简单的共通进制转换函数。


#include "stdafx.h"

#include <vector>
#include <iostream>
#include <algorithm>

using namespace std;

//任意进制转换函数
//oldNum为转换前的数字,oldHex则是转换前的进制
//newNum为转换后的数字,newHex则是转换后的进制
bool HexChange( vector<int> oldNum, int oldHex, vector<int>& newNum, int newHex)
{
	if(oldNum.size() < 1 || oldHex < 2 || newHex < 2)
		return false;

	newNum.clear();
	bool HexTest = true;

    while(HexTest)
    {
        HexTest = false;
        int remainder = 0;//每位的余数
		for(size_t i = 0; i<oldNum.size();++i)
        {
            int tempNum = (remainder * oldHex + oldNum[i]) / newHex;
            remainder = (remainder*oldHex + oldNum[i]) % newHex;
            if(tempNum != oldNum[i])//整个oldNum会逐渐变小,直到不再改变
            {
                oldNum[i] = tempNum;
                HexTest = true;
            }
        }
        if(HexTest)
        {
			newNum.push_back(remainder);
            remainder = 0;
        }
    }
	reverse(newNum.begin(),newNum.end());//倒转
    return true;
}

int _tmain(int argc, _TCHAR* argv[])
{
	//十进制:5459
	vector<int> oldNum;
	oldNum.push_back(7);
	oldNum.push_back(4);
	oldNum.push_back(5);
	oldNum.push_back(9);

	vector<int> newNum;

    //转16进制得到:1,13,2,3	
	if(HexChange(oldNum,10,newNum,16))
	{
		for(size_t i = 0; i < newNum.size(); ++i)
			cout<<newNum[i]<<",";
	}

	//转2进制得到:1110100100011
	if(HexChange(oldNum,10,newNum,2))
	{
		cout<<endl;
		for(size_t i = 0; i < newNum.size(); ++i)
			cout<<newNum[i];
	}
	return 0;
}


### 实现二进制转换函数 在多种编程语言中,二进制转换是一个常见的需求。以下是几种常见方式及其具体实现。 #### 使用 Python 的内置函数 `bin()` 进行十进制到二进制换 Python 提供了一个简单的方法来完成这一任务——`bin()` 函数。该函数接受一个整数作为输入并返回其对应的二进制表示形式(以字符串的形式)。需要注意的是,返回的结果会带有前缀 `'0b'` 表明这是一个二进制数值[^1]。 ```python def convertToBinary(x): if isinstance(x, int): # 确保输入为整型 return bin(x)[2:] if x >= 0 else '-' + bin(abs(x))[2:] raise ValueError("Input must be an integer") print(convertToBinary(10)) # 输出: 1010 print(convertToBinary(-10)) # 输出: -1010 ``` 上述代码定义了一个名为 `convertToBinary` 的函数,它能够处理正负整数,并移除了默认附加的 `'0b'` 前缀。 #### 不使用内置函数的手动实现 (Python) 如果不想依赖于内置函数,则可以通过手动计算的方式实现同样的功能: ```python def manual_convert_to_binary(n): if n == 0: return "0" negative = False if n < 0: negative = True n = abs(n) result = "" while n > 0: remainder = n % 2 result = str(remainder) + result n //= 2 return "-" + result if negative else result print(manual_convert_to_binary(10)) # 输出: 1010 print(manual_convert_to_binary(-10)) # 输出: -1010 ``` 此版本通过不断取模运算获取每一位上的值,并将其拼接起来形成最终结果[^2]。 #### C 语言中的二进制转换函数 对于C语言来说,虽然没有像Python那样直接提供类似的内置函数,但我们仍然可以自己编写这样的工具函数。下面展示了一种基于位操作的技术用于将二进制化为相应的十进制数值[^3]: ```c unsigned int bin_str_to_int(const char *pbin) { unsigned int i = 0; const char *ptr = pbin; while (*ptr && (*ptr == '0' || *ptr == '1')) { i <<= 1; // 左移一位相当于乘以2 i |= (*ptr++) - '0'; // 加上当前位的值 } return i; } // 测试用例 #include <stdio.h> int main(void){ char *binaryStr="1101"; printf("%u\n", bin_str_to_int(binaryStr)); // 应打印出13 } ``` 这段代码展示了如何逐字符读取给定的二进制字符串,并逐步构建起它的十进制等价物。 ### 总结 无论是采用高级脚本语言还是低级系统编程语言,在面对不同场景下的数据类型换时都有各自适用的最佳实践方案可供选择。以上介绍了几个典型例子帮助理解这些概念的应用过程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

丈八涯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值