华为2017年8月30日校招编程真题2-自定义的26进制和十进制之间互相转换

题目

二十六进制和十进制之间转换。
使用字符-十进制之间的关系
a-1
b-2

z-26
aa-27
ab-28
….
huawei-104680767

现在,输入字符串或者整数,要求输出对应的整数或者字符串。


思路


AC(通过70+%,没查出错误)

package test.test2;

import org.junit.Test;

/**
 * description:
 *
 * @author liyazhou
 * @since 2017-08-30 19:57
 */
public class Main {

    @Test
    public void test(){
       String[] strs = {"a",
                        "aa",
                        "aaa",
                        "ab",
                        "az",
               "z",
               "i",
               "huawei",
               "26",
               "27",
               "27",
               "27",
               "104680767",
       };
       for (String str: strs){
           String result = convertTo26(str);
           System.out.println(str + " :: " + result);
       }
    }



//    public static void main(String[] args){
//        Scanner sc = new Scanner(System.in);
//        String s = sc.next();
//        String result = new Main().convertTo26(s);
//        System.out.println(result);
//    }

    public String convertTo26(String str){
        char[] chars = str.toCharArray();
        String result = "";
        if (chars[0] >= '0' && chars[0] <= '9'){
            result = numToStr(chars);
        }else{
            result = strToNum(chars) + "";
        }

        return result;
    }

    private String numToStr(char[] chars){
        StringBuilder result = new StringBuilder();
        int num = Integer.valueOf(new String(chars));
        while (num != 0){
            int re = num % 26;
            if (re > 0){
                char r = (char)(re + ('a' - 1));
                result.append(r);
            }
            num  /= 26;
        }
        return result.reverse().toString();
    }

    private int strToNum(char[] chars){
        int num = 0;
        int counter = 0;
        int base = 1;
        for (int i = chars.length-1; i >= 0; i --){
            base = 1;
            for (int j = 0; j < counter; j ++){
                base *= 26;
            }
            num += (chars[i] - 'a' + 1) * base;
            counter ++;
        }
        return num;
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值