《算法笔记》系列----进制转换(q进制转十进制、十转q)

一、q进制转十进制

这个算法的核心就是变量product,我们先让product等于1代表这一位的大小,然后每一次都乘q,代表这一位的大小。

示例代码:

cpp 复制代码
int q,product,x;//假设这个x是一个q进制的数
int ans=0;
while(x){
  ans=ans+(x%10)*product;
   x=x/10; //x去掉一位
  product=product*q;  
}

二、十进制转q进制

我们要会这个算法,就要采用"除基取余法",下面来自算法笔记原话:

将十进制数y转换为Q进制数z。

采用"除基取余法"。所谓的"基",是指将要转换成的进制Q,因此除基取余的意思就是每次将待转换数除以Q,然后将得到的余数作为低位存储,而商则继续除以Q并进行上面的操作,最后当商为00时,将所有位从高到低输出就可以得到z。

结果存放于数组z将余数从后往前输出。

cpp 复制代码
int a[40],num=0,q;

do{
   a[num++]=y%q;
   y=y/q;
} whlile(y!=0);
相关推荐
你要飞15 分钟前
第一课:英语简单句的构成与运用
笔记·考研
fengyue011022 分钟前
C++使用epoll实现高并发tcp服务
linux·服务器·网络·c++
小无名呀24 分钟前
C++ 异常处理
c++
不穿格子的程序员28 分钟前
从零开始写算法——二叉树篇3:对称二叉树 + 二叉树直径
算法
米优42 分钟前
C/C++中实现自定义自动释放堆内存空间类
c语言·开发语言·c++
Hncj20221 小时前
项目02--JsonRpc
linux·c++·ubuntu·rpc
中屹指纹浏览器1 小时前
大模型赋能指纹浏览器:基于安全 GPT 的动态风控对抗与指纹生成技术
经验分享·笔记
binary思维1 小时前
C语言应用领域及操作Excel方法
c语言
QT 小鲜肉1 小时前
【Linux命令大全】001.文件管理之gitview命令(实操篇)
linux·运维·服务器·chrome·笔记
挖矿大亨1 小时前
C++中的引用
开发语言·c++