《算法笔记》系列----进制转换(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);
相关推荐
fie888915 小时前
NSCT(非下采样轮廓波变换)的分解和重建程序
算法
晨晖216 小时前
单链表逆转,c语言
c语言·数据结构·算法
清风一徐16 小时前
禅道从18.3升级到21.7.6版本
笔记
kk哥889916 小时前
C++ 对象 核心介绍
java·jvm·c++
Jack___Xue16 小时前
LangChain实战快速入门笔记(六)--LangChain使用之Agent
笔记·langchain·unix
helloworddm16 小时前
WinUI3 主线程不要执行耗时操作的原因
c++
零度@16 小时前
SQL 调优全解:从 20 秒到 200 ms 的 6 步实战笔记(附脚本)
数据库·笔记·sql
无能者狂怒17 小时前
YOLO C++ Onnx Opencv项目配置指南
c++·opencv·yolo
im_AMBER17 小时前
Leetcode 78 识别数组中的最大异常值 | 镜像对之间最小绝对距离
笔记·学习·算法·leetcode
集智飞行17 小时前
c++函数传参的几种推荐方式
开发语言·c++