1.使用Java带有的方法Integer,最简单粗暴了,代码如下

//使用java提供的方法
//但仅局限于比较常用的二进制、八进制、十六进制

  public static String trans1(int num, int radix)
  {
    if(radix == 2)
      return Integer.toBinaryString(num);
    else if(radix == 8)
      return Integer.toOctalString(num);
    else if(radix == 16)
      return Integer.toHexString(num);

    return null;
  }

2.使用数组进行交换,贴码:

//使用数组的形式进行转换
  public static void trans2(int num, int radix)
  {
    System.out.println(num+"转成"+radix+"进制数为:");

    //创建数组,32位
    char[] arr = new char[32];

    //创建参考字符数组
    char[] ch = {
      '0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'
    };

    //指针,从数组最后开始
    int pos = 32;

    //开始循环计算num和radix的商和余数
    while(num > 0)
    {
      arr[--pos] = ch[num % radix];
      num /= radix;

      /*
       * 这里是针对二进制、八进制和十六进制进行的移位运算
      arr[--pos] = ch[num&(radix-1)];
      if(radix == 2)
        num >>= 1;
      else if(radix == 8)
        num >>= 3;
      else if(radix == 16)
        num >>= 4;
      */
    }

    //输出有效的进制数
    for(int i = pos; i < 32; i++)
      System.out.print(arr[i]);

    System.out.println();
  }

3.使用StringBuilder类型,贴码:

//使用StringBuilder进行转换
  public static String trans3(int num, int radix)
  {
    //使用StringBuilder的reverse方法
    StringBuilder sb = new StringBuilder();

    while(num > 0)
    {
      //把除以基数的余数存到缓冲区中
      sb.append(num % radix);
      num /= radix;
    }

    return sb.reverse().toString();
  }
import java.util.*;


public class Solution {
    /**
     * 进制转换
     * @param M int整型 给定整数
     * @param N int整型 转换到的进制
     * @return string字符串
     */
    public String solve (int M, int N) {
        if(M == 0) return "0";
        boolean flag = true;
        if(M < 0){
            M = -M;
            flag = false;
        }
        String hex = "0123456789ABCDEF";
        StringBuffer sb = new StringBuffer();
        while(M != 0){
            sb.append(hex.charAt(M%N));
            M /= N;
        }
        return  flag == true ? sb.reverse().toString() : "-"+sb.reverse().toString();
    }
}