将十进制x转换为D进制的y:
【方法】:整数采用“除基取余法”,小数采用“乘基取整法”
【推导】:以三位D进制为例,假设y的各位是a1a2a3
y
=
a
1
D
2
+
a
2
D
1
+
a
3
D
0
=
a
1
D
2
+
a
2
D
1
+
a
3
y = a1D^2+a2D^1+a3D^0=a1D^2+a2D^1+a3
y=a1D2+a2D1+a3D0=a1D2+a2D1+a3
y
/
D
=
a
1
D
1
+
a
2
D
0
.
.
.
.
.
.
a
3
y/D= a1D^1+a2D^0......a3
y/D=a1D1+a2D0......a3
y
/
D
/
D
=
a
1
D
0
.
.
.
.
.
.
a
2
y/D/D= a1D^0......a2
y/D/D=a1D0......a2
y
/
D
/
D
/
D
=
0......
a
1
y/D/D/D= 0......a1
y/D/D/D=0......a1
【总结】先得到的为低位如a3,最后商为0得最高位如a1
【代码】
int ans[100];
num=0;
while(y != 0){
ans[num++]=y%D;
y = y/D;
}