七进制数、36进制加法

/**
 * 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进制
 *
 * @param args
 */

 

/**
 * @Auther: liuhaidong
 * Data: 2019/11/21 0021、11:40
 * Description:
 * @version: 1.0
 */
public class Main {
    public static void main(String [] args) {
        String result = addFunWithStr("1b", "2x");
        System.out.println("result = " + result);
    }

    /**
     * 获取值
     * @param ch
     * @return
     */
    public static int getIntFromChar(char ch) {
        int ret = -1;
        if (ch >='0' && ch <= '9') {
            ret = ch - '0';
        } else if (ch >= 'a' && ch <= 'z') {
            ret = (ch - 'a') + 10;
        }
        return ret;
    }

    public static String addFunWithStr(String param1, String param2) {

        StringBuffer stringBuffer = new StringBuffer();
        String symbol = "0123456789abcdefghijklmnopqrstuvwxyz";
        int param1Len = param1.length();
        int param2Len = param2.length();

        int i = param1Len - 1;
        int j = param2Len - 1;

        if (i < 0 || j < 0) {
            return null;
        }

        int temp = 0;
        while (i >= 0 && j >= 0) {
            char ch_1 = param1.charAt(i);
            char ch_2 = param2.charAt(j);

            int v1 = getIntFromChar(ch_1);
            int v2 = getIntFromChar(ch_2);

            int ret = v1 + v2;
            if (ret >= 36) {
                int index = ret - 36 + temp;
                char sv = symbol.charAt(index);
                stringBuffer.append(sv);
                temp = 1; //进位
            } else {
                int index = ret + temp;
                char sv = symbol.charAt(index);
                stringBuffer.append(sv);
                temp = 0;
            }
            i--;
            j--;
        }

        while (i >= 0) {
            char ch_1 = param1.charAt(i);
            stringBuffer.append(ch_1);
            i--;
        }
        while (j >= 0) {
            char ch_2 = param2.charAt(i);
            stringBuffer.append(ch_2);
            j--;
        }

        StringBuffer result = stringBuffer.reverse();
        return result.toString();
    }
}

七进制数

给定一个整数,将其转化为7进制,并以字符串形式输出。

示例 1:

输入: 100
输出: "202"
示例 2:

输入: -7
输出: "-10"
注意: 输入范围是 [-1e7, 1e7] 。

 

基本思路就是迭代除7取余,存到一个StringBuilder里,最后反转即可。
对于负数,直接先取正处理,然后加上负号即可。

 

class Solution {
    public String convertToBase7(int num) {
        String ans = "";
        if (num < 0) {
            num = 0 - num;
            ans += "-";
        };
        StringBuilder sb = new StringBuilder();
        do {
            int mod = num % 7;
            sb.append((char)('0'+mod));
            num = num / 7;
        } while (num > 0);
        ans += sb.reverse().toString();
        return ans;

    }
}