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
请按任意键继续. . .
相关推荐
huluang2 分钟前
Word文档批注智能克隆系统的设计与实现
开发语言·c#·word
superman超哥4 分钟前
仓颉设计哲学核心:零成本抽象的实现原理与深度实践
开发语言·仓颉编程语言·仓颉·零成本抽象·仓颉设计
山上三树8 分钟前
柔性数组(C语言)
c语言·开发语言·柔性数组
MarkHD8 分钟前
智能体在车联网中的应用:第31天 基于RLlib的多智能体PPO实战:MAPPO算法解决simple_spread合作任务
算法
IT猿手10 分钟前
三维动态避障路径规划:基于部落竞争与成员合作算法(CTCM)融合动态窗口法DWA的无人机三维动态避障方法研究,MATLAB代码
算法·matlab·动态规划·无人机·路径规划·动态路径规划
郝学胜-神的一滴11 分钟前
机器学习数据集完全指南:从公开资源到Sklearn实战
人工智能·python·程序人生·机器学习·scikit-learn·sklearn
T0uken13 分钟前
现代 C++ 项目的 CMake 工程组织
c++
不要em0啦15 分钟前
从0开始学python:简单的练习题3
开发语言·前端·python
老华带你飞15 分钟前
电商系统|基于java + vue电商系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端