《算法笔记》系列----进制转换(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);
相关推荐
RaLi和夕1 天前
硬件电路设计学习笔记3.比较器
笔记·嵌入式硬件·学习
Sunflower_ac1 天前
线性代数学习笔记(未完结)
人工智能·笔记·学习·线性代数·机器学习
sin_hielo1 天前
leetcode 1411(递推)
数据结构·算法·leetcode
兵哥工控1 天前
mfc一个简单完整调用动态链接库实例
c++·mfc
一起养小猫1 天前
LeetCode100天Day10-单词规律与同构字符串
java·开发语言·数据结构
颜酱1 天前
学习卡特兰数:从原理到应用,解决所有递推计数问题
前端·javascript·算法
fanged1 天前
RASPI裸机1(TODO)
笔记
漫随流水1 天前
leetcode算法(20.有效的括号)
数据结构·算法·leetcode
如果你想拥有什么先让自己配得上拥有1 天前
数、自然数、整数、有理数、无理数它们的定义由来和边界划分
算法
sayang_shao1 天前
C++智能指针【笔记】
开发语言·c++·笔记