1 Star 0 Fork 0

ccyy-阿亮/datastructures_ts

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
base-converter.ts 1.28 KB
一键复制 编辑 原始数据 按行查看 历史
ccyy-阿亮 提交于 2020-05-12 00:01 +08:00 . 栈的markdown文件说明
import Stack from '../data-structures/stack-object';
/**
* 十进制转换为二进制
*/
export function decimalToBinary(decNumber: number) {
const remStack: Stack<number> = new Stack();
let rem: number;
let binaryString: string = '';
while (decNumber > 0) {
rem = Math.floor(decNumber % 2); // 取余
remStack.push(rem); // 将余数推进栈里
decNumber = Math.floor(decNumber / 2); // 用商更新待处理数
}
while (!remStack.isEmpty()) {
binaryString += remStack.pop().toString(); // 取栈顶的数
}
return binaryString;
}
/**
* 十进制转换为任意进制
*/
export function baseConverter(decNumber: number, base: number) {
const remStack: Stack<number> = new Stack<number>();
const digits: string = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ';
let rem: number;
let baseString: string = '';
if (!(base >= 2 && base <= 36)) {
return '';
}
while (decNumber > 0) {
rem = Math.floor(decNumber % base); // 取余
remStack.push(rem); // 将余数推进栈里
decNumber = Math.floor(decNumber / base); // 用商更新待处理数
}
while (!remStack.isEmpty()) {
baseString += digits[remStack.pop()]; // 取栈顶的数
}
return baseString;
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
TypeScript
1
https://gitee.com/liawnliu/datastructures_ts.git
git@gitee.com:liawnliu/datastructures_ts.git
liawnliu
datastructures_ts
datastructures_ts
master

搜索帮助