C++:万能进制转换

目录

引言

本文介绍的这个 p p p 进制与十进制之间的转换,主要是针对算法竞赛中的,对于一些特殊情况,比如说字母大小写、前导零、非法输入的处理等这些问题其实都没有去深究,因为在算法竞赛中给你的数据都是合法的,然后只需要你跟据这个来进行简单的转换即可。而对于要实现一些库函数,怎么确保它的安全性和正确性,暂时先不考虑了。


一、p进制转为十进制

思路:字符串最左边的下标是从 0 0 0 开始的,所以说 0 0 0 号下标是权重最大的了。我们依次从 0 0 0 号下标开始遍历,每一次都将现有的数乘以 p p p ,相当于左移了一位,然后再加上当前的值。动态的想:先将当前数全部向左移一位,然后再加上当前位的数。然后就是对数字和字母的处理了,详情见代码。

cpp 复制代码
int p_to_ten(string s, int p)  // p进制字符串 转换为 十进制数 
{
	int res = 0;
	for(int i = 0; i < s.size(); ++i)
	{
		res *= p;
		if(s[i] >= 'A' && s[i] <= 'Z') res += s[i] - 'A' + 10;
		else res += s[i] - '0';
	}
	return res;
}

二、十进制转换为p进制

思路:类比于十进制数,第一次取模所得的数是最低位的数,然后对原本的数除以 p p p ,相当于将整个数向右移了一位,然后再取模,相当于取第二个数的模,就这样重复此过程,直到为 0 0 0 。因为第一次添加的数相当于是低位,而我们是依次向后添加数的,所以最后翻转一下,就是最终的结果了。

cpp 复制代码
string ten_to_p(int nums, int p)  // 十进制数 转换为 p进制字符串 
{
	string res;
	while(nums)
	{
		int t = nums % p;
		if(t < 10) res.push_back(t + '0');
		else res.push_back(t - 10 + 'A');
		nums /= p;
	}
	reverse(res.begin(), res.end());
	return res;
}

三、测试

测试用例:

cpp 复制代码
#include <iostream>
#include <algorithm>

using namespace std;

int p_to_ten(string s, int p)  // p进制字符串 转换为 十进制数 
{
	int res = 0;
	for(int i = 0; i < s.size(); ++i)
	{
		res *= p;
		if(s[i] >= 'A' && s[i] <= 'Z') res += s[i] - 'A' + 10;
		else res += s[i] - '0';
	}
	return res;
}

string ten_to_p(int nums, int p)  // 十进制数 转换为 p进制字符串 
{
	string res;
	while(nums)
	{
		int t = nums % p;
		if(t < 10) res.push_back(t + '0');
		else res.push_back(t - 10 + 'A');
		nums /= p;
	}
	reverse(res.begin(), res.end());
	return res;
}

int main() {  
    // 二进制转十进制  
    std::string binary = "1010";  
    int decimal_from_binary = p_to_ten(binary, 2);  
    std::cout << "Binary " << binary << " to decimal: " << decimal_from_binary << std::endl;  
  
	// 十进制转二进制  
    int decimal = 10;  
    std::string binary_from_decimal = ten_to_p(decimal, 2);  
    std::cout << "Decimal " << decimal << " to binary: " << binary_from_decimal << std::endl;    
  
    // 八进制转十进制  
    std::string octal = "765";  
    int decimal_from_octal = p_to_ten(octal, 8);  
    std::cout << "Octal " << octal << " to decimal: " << decimal_from_octal << std::endl;  
  
    // 十进制转八进制  
    int another_decimal = 501;  
    std::string octal_from_decimal = ten_to_p(another_decimal, 8);  
    std::cout << "Decimal " << another_decimal << " to octal: " << octal_from_decimal << std::endl;  
  
    // 十进制转十六进制  
    int hex_decimal = 2765;  
    std::string hex_uppercase = ten_to_p(hex_decimal, 16);  
    std::cout << "Decimal " << hex_decimal << " to hex: " << hex_uppercase << std::endl;  
    
    // 十六制转十进制  
    std::string hex = "ACD";  
    int decimal_from_hex = p_to_ten(hex, 16);  
    std::cout << "Hex " << hex << " to decimal: " << decimal_from_hex << std::endl;  
  
    return 0;  
}

测试结果:

Binary 1010 to decimal: 10
Decimal 10 to binary: 1010
Octal 765 to decimal: 501
Decimal 501 to octal: 765
Decimal 2765 to hex: ACD
Hex ACD to decimal: 2765

--------------------------------
Process exited after 0.114 seconds with return value 0
请按任意键继续. . .
相关推荐
奋斗的小花生42 分钟前
c++ 多态性
开发语言·c++
魔道不误砍柴功1 小时前
Java 中如何巧妙应用 Function 让方法复用性更强
java·开发语言·python
pianmian11 小时前
python数据结构基础(7)
数据结构·算法
Nu11PointerException1 小时前
JAVA笔记 | ResponseBodyEmitter等异步流式接口快速学习
笔记·学习
闲晨1 小时前
C++ 继承:代码传承的魔法棒,开启奇幻编程之旅
java·c语言·开发语言·c++·经验分享
老猿讲编程1 小时前
一个例子来说明Ada语言的实时性支持
开发语言·ada
UestcXiye2 小时前
《TCP/IP网络编程》学习笔记 | Chapter 3:地址族与数据序列
c++·计算机网络·ip·tcp
Chrikk2 小时前
Go-性能调优实战案例
开发语言·后端·golang
亦枫Leonlew2 小时前
三维测量与建模笔记 - 3.3 张正友标定法
笔记·相机标定·三维重建·张正友标定法
幼儿园老大*2 小时前
Go的环境搭建以及GoLand安装教程
开发语言·经验分享·后端·golang·go