题目描述:
36进制由0-9,a-z,共36个字符表示,最小为’0’
- ‘0’'9’对应十进制的09,‘a’'z’对应十进制的1035
- 例如:‘1b’ 换算成10进制等于 1 * 36^1 + 11 * 36^0 = 36 + 11 = 47
- 要求按照加法规则计算出任意两个36进制正整数的和
- 如:按照加法规则,计算’1b’ + ‘2x’ = ‘48’
(要求:不允许把36进制数字整体转为10进制数字,计算出10进制数字的相加结果再转回为36进制)
js代码:
<script type="text/javascript">
function single(k){
var char_k2 = a.charAt(k);
var char_kn2 = map1.get(char_k2);
var sum = char_kn2 + temp;
if(sum >= 36){
var sum = sum - 36;
result.unshift(sum);
temp = 1
}else{
result.unshift(sum);
temp = 0;
}
k--;
}
//a,b分别为两个36进制数字的字符串形式
function add(a,b){
var map1 = new Map([["0",0],[