部分进制间的转换

简介: 部分进制间的转换

文章目录


十进制转换为十六进制

十六进制转换为十进制

十六进制转八进制的三种方法


十进制转换为十六进制


import java.util.Scanner;
public class Main {
  public static void main(String[] args) {
    Scanner src=new Scanner(System.in);
    long n=src.nextLong();
    String arry=Long.toHexString(n);
    arry=arry.toUpperCase();
    System.out.println(arry);   
  }
}

十六进制转换为十进制


import java.util.Scanner; 
public class t14 {
  public static void main(String[] args) {
    Scanner scanner = new Scanner(System.in);
    String string = scanner.nextLine();
      System.out.println(Long.valueOf(string,16));    //方法一
      System.out.println(Long.parseLong(string, 16));  //方法二
  }
}

十六进制转八进制的三种方法


import java.util.Arrays;
import java.util.Scanner;
 class Main {
  //第一种方法就是用Integer.parseInt(a,b); 
  //接收字符串a然后以b进制去接受它
  //再用Integer.toString(a, b)把a从十进制转换成b进制的数字
//  public static void main(String[] args) {
//    Scanner sc =new Scanner(System.in);
//    int n = sc.nextInt();
//    for (int i = 0; i <n; i++) {
//      String a = sc.next();
//      int b = Integer.parseInt(a,16);
//    //  System.out.println(b);
//      String ss =Integer.toString(b, 8);
//      System.out.println(ss);
//    }
//  }
  //第二种方法就是Integer类自带的二进制,八进制,十六进制
  //Integer.valueOf(a, b)这个的用法和上面那个parseInt一样
//    public static void main(String[] args) {
//          Scanner in=new Scanner(System.in);
//          int n=in.nextInt();
//          String [] result=new String[11];
//          for(int i=0;i<n;i++){
//                  String h=in.next();
//              String b=Integer.toBinaryString(Integer.valueOf(h, 16));
//              String o=Integer.toOctalString(Integer.valueOf(b, 2));
//              result[i]=o;
//          }
//          for(int i=0;i<n;i++){
//                  System.out.println(result[i]);
//          }
//      }
  //第三种就是比较传统的自己写出各种进制的表,这里就要用到二进制和八进制的关系了
  //这里大概说一下,如果想继续钻研的可以自己百度一下
  //因为是这里最高是16进制每一个二进制的里面都对着一个16进制的数字
  //因为正好2的4次方是16进制,2进制的四位数正好把每一个四进制的数都一一对应着
  //取得时候直接按照相等的值取就可以了
  //这道题就是先把16进制转换成二进制,再按照对应的方法取八进制对应的值
  public static void main(String[] args) {
    // 接受输入 n
    Scanner scanner = new Scanner(System.in);
    String input_n = scanner.nextLine();
    int n = Integer.parseInt(input_n);
    // 接受输入十六进制数的字符串
    String[] input_nums = new String[n];
    for (int i = 0; i < n; i++) {
      input_nums[i] = scanner.nextLine();
    }
    scanner.close();
    // 十六进制表
    String[] HEXs = { 
      "0", "1", "2", "3", "4", "5", "6", "7", 
      "8", "9", "A", "B", "C", "D", "E", "F"
    };
    // 二进制表
    String[] BINs = { 
      "0000", "0001", "0010", "0011", "0100", "0101", "0110", "0111", 
      "1000", "1001", "1010", "1011", "1100", "1101", "1110", "1111" 
    };
    // 八进制表
    String[] OCTs = { 
      "0", "1", "2", "3", "4", "5", "6", "7"
    };
    // 十六进制表和二进制表,在所有成员上值一一对应
    // 十六进制表、二进制表和八进制表,在前八位成员上值一一对应
    for (int m = 0; m < n; m++) { // 遍历每个十六进制数字
      String hex = input_nums[m]; // 十六进制表示形式
      StringBuffer sbBin = new StringBuffer();
      StringBuffer sbOct = new StringBuffer();
      // 十六进制转二进制
      // 将十六进制数每一位转换成四位的二进制数字
      for (int i = 0; i < hex.length(); i++) { // 遍历每个十六进制位
        String c = Character.toString(hex.charAt(i));
        // 查询当前位字符在 HEXs中的下标
        int index = Arrays.binarySearch(HEXs, c);
        sbBin.append(BINs[index]);
      }
      // 在二进制数前面插入若干个"0",使得二进数的位数为 3 的倍数
      while (sbBin.length() % 3 != 0) {
        sbBin.insert(0, "0");
      }
      int octLen = sbBin.length() / 3; // 计算目标八进制数的长度
      // 每次取三位二进制数,转换成对应的八进制
      for (int i = 0; i < octLen; i++) {
        String span = sbBin.substring(3 * i, 3 * i + 3);
        int index = Arrays.binarySearch(BINs, "0" + span);
        sbOct.append(OCTs[index]);
      }
      // 此时已经得到结果,需要去除前导 0
      while (sbOct.charAt(0) == '0') {
        sbOct.delete(0, 1);
      }
      System.out.println(sbOct.toString());
    }
  }
}


相关文章
|
8天前
|
人工智能 自然语言处理 文字识别
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
Qwen3.7-Max是阿里云百炼面向智能体时代推出的新一代旗舰模型,对标GPT-5.5、Claude Opus 4.7等闭源旗舰。该模型支持百万级token上下文窗口,具备顶级推理能力、多模态搜索与视觉理解增强、流式输出低延迟响应等核心优势,覆盖编程、办公、长周期自主执行等复杂场景。同时支持OpenAI接口兼容,便于系统快速迁移。用户可通过Token Plan团队或节省计划等订阅方式灵活调用,适合企业级高要求场景使用。
3545 15
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
|
15天前
|
人工智能 开发工具 iOS开发
Claude Code 新手完全上手指南:安装、国产模型配置与常用命令全解
Claude Code 是一款运行在终端环境中的 AI 编程助手,能够直接在命令行中完成代码生成、项目分析、文件修改、命令执行、Git 管理等开发全流程工作。它最大的特点是**任务驱动、终端原生、轻量高效、多模型兼容**,无需图形界面、不依赖 IDE 插件,能够深度融入开发者日常工作流。
3577 12
|
9天前
|
人工智能 自然语言处理 供应链
|
12天前
|
人工智能 Linux BI
国内用 Claude Code 终于不用翻墙了:一行命令搞定,自动接 DeepSeek
JeecgBoot AI专题研究 一键脚本:Claude Code + JeecgBoot Skills + DeepSeek 全平台接入 一行命令装好 Claude Code + JeecgBoot Skills + DeepSeek 接入,无需翻墙使用 Claude Code,支持 Wind
2944 7
国内用 Claude Code 终于不用翻墙了:一行命令搞定,自动接 DeepSeek
|
18天前
|
Shell API 开发工具
Claude Code 快速上手指南(新手友好版)
AI编程工具卷疯啦!Claude Code凭借任务驱动+终端原生的特性,成了开发者的效率搭子。本文从安装、登录、切换国产模型到常用命令,手把手带新手快速上手,全程避坑,30分钟独立用起来。
3695 25
|
9天前
|
人工智能 自然语言处理 安全
Claude Code 全攻略:命令大全+三种模式+记忆体系+实战工作流完整手册
Claude Code 是当前最流行的终端级 AI 编程助手,能够直接在命令行中完成代码生成、项目理解、文件修改、命令执行、错误修复等全流程开发工作。它不依赖图形界面、不占用额外资源,却能深度理解项目结构,自动生成规范代码,大幅提升研发效率。
1430 3
|
2天前
|
存储 定位技术 数据库
CodeGraph 如何让 Claude Code减少 7 成工具调用?
CodeGraph 为 Coding Agent 提供本地代码知识图谱,把函数、类、调用链和框架路由提前整理成“项目地图”,减少盲目搜索和文件读取。它不是新 Agent,而是上下文基础设施,让 Agent 更快找到正确代码路径,平均减少 7 成工具调用。
428 0
|
16天前
|
存储 Linux iOS开发
【2026最新】MarkText中文版Markdown编辑器使用图解(附安装包)
MarkText是一款免费开源、跨平台的Markdown编辑器,主打所见即所得实时预览,支持Windows/macOS/Linux。内置数学公式、流程图、代码高亮、多主题及PDF/HTML导出,是Typora的轻量免费替代首选。(239字)